最近在看《深入浅出MyBatis技术原理与实践》,此篇作为读后笔记一。
第一章 简介
说道Mybatis 就要知道什么是ORM模型(Object Relational Mapping)对象关系映射。它是一种程序技术,主要解决POJO对象和数据库数据之间相互映射,将程序中的对象自动持久化到关系数据库中,或者将数据库中的数据转化为POJO。
Hibernate 和 MyBatis
Hibernate 是一个开放源代码的ORM框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
Hibernate和 MyBatis的优缺点
Hibernate 的优点
1.hibernate是全自动,完全可以通过对象关系模型实现对数据库的操作,拥有完整的JavaBean对象与数据库的映射结构来自动生成sql。消除了代码的映射规则,只需在xml或者注解中配置即可。
2.无序管理数据库连接,它也配置在xml里面。
3.有更好的二级缓存机制,可以使用第三方缓存。
4.一个会话中不用操作多个对象,只要操作Session对象就可以。同样关闭资源只要关闭Session即可。
5.hibernate拥有完整的日志系统,涉及广泛,包括sql记录、关系异常、优化警告、缓存提示、脏数据警告等。
6.可移植性强。
Hibernate 的缺点
1.全表映射有时很不方便,比如修改个别字段也要发送所有字段。
2.无法根据不同的条件组装不同的SQL。
3.多表关联和复杂的SQL支持较差,不支持存储过程。
4.优化SQL能力太差。
5.sql很多都是自动生成的,无法直接维护sql,虽然有hql查询,但功能还是不及sql强大,见到报表等变态需求时,hql查询要弱些,也就是说hql查询是有局限的。
MyBatis 的优点
1.针对高级查询,Mybatis需要手动编写SQL语句,以及ResultMap。SQL更灵活,适用于多表查询。
2.可以进行更为细致的SQL优化,提供xml标签,支持编写动态sql,同时支持存储过程,满足各种应用系统和互联网应用的变化需求。
3.数据Mapper接口编程根据xml创建映射器。简化工作便于集中业务程序。
MyBatis 的缺点
1.关联表多时,字段多的时候,sql工作量很大。
2.sql依赖于数据库,导致数据库移植性差。
3.编写动态sql时,不方便调试,尤其逻辑复杂时。
第二章 入门
MyBatis 的核心组件
1.SqlSessionFactoryBuilder 构造器
它可以从XML配置文件或一个预先定制的Configuration的实例构建SqlSessionFactory。构建的Builder 模式。
2.SqlSessionFactory 工厂接口
每一个MyBatis的应用程序都以一个S