熟悉 Java 的同学应该知道, 是一个 。。说得更具体点就是,ORM 负责将程序中的对象存储到数据库中、将数据库中的数据转化为程序中的对象。
在剖析 Spring 框架的时候,我们讲到,如果用一句话来总结框架作用的话,那就是简化开发。。那 MyBatis 是如何简化数据库开发的呢?我们结合第 JdbcTemplate 的例子来说明一下。
使用 JdbcTemplate 进行数据库编程,我们只需要编写跟业务相关的代码(比如,SQL 语句、数据库中数据与对象之间的互相转化的代码),其他流程性质的代码(比如,加载驱动、创建数据库连接、创建 statement、关闭连接、关闭 statement 等)都封装在了 JdbcTemplate 类中,不需要我们重复编写。
当时,为了展示使用 JdbcTemplate 是如何简化数据库编程的,我们还举了一个查询数据库中用户信息的例子。还是同样这个例子,我再来看下,使用 MyBatis 该如何实现,是不是比使用 JdbcTemplate 更加简单。
(比如,访问 MySQL 的 JDBC 驱动实现类库 mysql-connector-java.jar)。将两个 jar 包引入项目之后,我们就可以开始编程了。使用 MyBatis 来访问数据库中用户信息的代码如下所示:
需要注意的是,在 配置文件中,我们只定义了接口和 SQL 语句之间的映射关系,并没有显式地定义类(UserDo)字段与数据库表(user)字段之间的映射关系。实际上,。当然,如果没办法做到一一映射,我们也可以自定义它们之间的映射关系。
有了上面的代码和配置,我们就可以像下面这样来访问数据库中的用户信息了。
从代码中,我们可以看出,相对于使用 的实现方式,使用 的实现方式更加灵活。在使用 JdbcTemplate 的实现方式中,对象与数据库中数据之间的转化代码、SQL 语句,是硬编码在业务代码中的。而,这样会更加灵活、清晰,维护起来更加方便。
刚刚我们对 MyBatis 框架做了简单介绍,接下来,我们再对比一下另外两个框架: 和 。通过对比我们来看,MyBatis 是如何权衡代码的易用性、性能和灵活性的。
我们先来看 JdbcTemplate。相对于 MyBatis 来说,。相对于其他两个框架来说,它的性能最好。但是,它的缺点也比较明显,那就是 SQL 与代码耦合在一起,而且不具备 ORM 的功能,需要自己编写代码,解析对象跟数据库中的数据之间的映射关系。所以,在易用性上它不及其他两个框架。
我们再来看 Hibernate。相对于 MyBatis 来说,Hibernate 更加重量级。我们不需要像使用 MyBatis 那样自己编写 SQL。因此,有的时候,我们也把 MyBatis 称作半自动化的 ORM 框架,把 Hibernate 称作全自动化的 ORM 框架。不过,虽然自动生成 SQL 简化了开发,但是毕竟是自动生成的,没有针对性的优化。在性能方面,这样得到的 SQL 可能没有程序员编写得好。同时,这样也丧失了程序员自己编写 SQL 的灵活性。
实际上,不管用哪种实现方式,从数据库中取出数据并且转化成对象,这个过程涉及的代码逻辑基本是一致的。不同实现方式的区别,只不过是哪部分代码逻辑放到了哪里。有的框架提供的功能比较强大,大部分代码逻辑都由框架来完成,程序员只需要实现很小的一部分代码就可以了。这样框架的易用性就更好些。但是,框架集成的功能越多,为了处理逻辑的通用性,就会引入更多额外的处理代码。比起针对具体问题具体编程,这样性能损耗就相对大一些。
所以,粗略地讲,有的时候,框架的易用性和性能成对立关系。追求易用性,那性能就差一些。
相反,追求性能,易用性就差一些。除此之外,使用起来越简单,那灵活性就越差。这就好比我们用的照相机。傻瓜相机按下快门就能拍照,但没有复杂的单反灵活。实际上,JdbcTemplate、MyBatis、Hibernate 这几个框架也体现了刚刚说的这个规律。
。Hibernate 提供的功能最完善,易用性最好,但相对来说性能损耗就最高了。MyBatis 介于两者中间,在易用性、性能、灵活性三个方面做到了权衡。它支撑程序员自己编写 SQL,能够延续程序员对 SQL 知识的积累。。这也提醒我们,过度封装,提供过于简化的开发方式,也会丧失开发的灵活性。
- ORM 框架主要是根据之间的映射关系,帮助程序员
87 | 开源实战五(上):MyBatis如何权衡易用性、性能和灵活性?
版权声明:
本文来源网络,所有图片文章版权属于原作者,如有侵权,联系删除。
本文网址:https://www.mushiming.com/mjsbk/14881.html