Java 核心技术

JPA和MyBatis如何进行技术选型

2020-02-23  本文已影响0人  cbw100

背景

在我们平时的项目中,大家都知道可以使用JPA或者Mybatis作为ORM 层。对JPA和Mybatis如何进行技术选型?(http://www.spring4all.com/question/112

我将从以下几个方面进行总结。

MySQL数据库使用规范

核心规范

字段类规范

索引类规范

SQL类规范

两者区别

MyBatis

MyBatis是一个半自动化的持久层框架,支持定制化SQL、存储过程以及高级映射;避免了几乎所有的 JDBC代码和手动设置参数以及获取结果集,并且可以使用简单的XML或注解来配置和映射原生信息,将接口和Java的POJOs映射成数据库中的记录。

  1. 简单易学;
  2. 灵活,MyBatis不会对应用程序或者数据库的现有设计强加任何影响。 注解或者使用SQL写在XML里,便于统一管理和优化。通过SQL基本上可以实现我们不使用数据访问框架可以实现的所有功能,或许更多。
  3. 解除SQL与程序代码的耦合,SQL和代码的分离,提高了可维护性。
  4. 提供映射标签,支持对象与数据库的OMR字段关系映射。
  5. 提供对象关系映射标签,支持对象关系组建维护。
  6. 提供XML标签,支持编写动态SQL。

JPA

最早接触JPA是在几年前使用seam框架的时候,JPA做为seam的持久层。JPA的宗旨是为POJO提供持久化标准规范,实现使用的Hibernate,Hibernate是一个全自动的持久层框架,并且提供了面向对象的SQL支持,不需要编写复杂的SQL语句,直接操作Java对象即可,从而大大降低了代码量,让即使不懂SQL的开发人员,也使程序员更加专注于业务逻辑的实现。对于关联查询,也仅仅是使用一些注解即可完成一些复杂的SQL功能。但是碰到复杂业务的SQL时,想要优化Hibernate这种全自动的OMR显得很费力。但是如果按照上面数据库的使用规范,将复杂的查询放到业务层进行处理,这是没有问题的。

工作以来这两个框架都接触一些,可能一般传统公司、个人开发用Hibernate(JPA)多些,互联网公司更多在用MyBatis。但对于以上两种框架,都提供了很方便的开发方式。

业务场景或团队开发习惯

借助工具,代码生成器

对于开发效率上来说,可以自己写一个代码生成工具,把通用的代码一键生成。

总结

相关文章:

上一篇下一篇

猜你喜欢

热点阅读