Mybatis与Hibernate
- 两者的设计初衷都是对JDBC进行包装,使得应用代码可以基于OOP来进行SQL的相关操作,即应用代码中可以通过POJO的方法调用来执行指定的SQL;
- Hibernate:POJO和数据表的映射,自动生成SQL,应用代码不需要定义相关SQL,直接调用POJO的相关方法即可;
- Mybatis:POJO和SQL的映射,需要在应用代码中提供SQL,mybatis提供基于POJO的方法调用来执行指定的SQL。
Mybatis的设计原理简述
- Mybatis的设计当中,主要是使用一个格式为XML的mapper文件来维护SQL集合,然后一个mapper.xml文件映射到一个mapper接口,或者说每个mapper接口对应一个mapper的命名空间namespace,一般mapper接口的接口名与mapper.xml文件名相同,mapper接口的每个方法对应mapper.xml文件的一个完整SQL。在应用代码中,通常为在DAO中,通过调用这个mapper接口的方法来执行对应的SQL。
- 在Mybatis内部执行SQL的过程中,首先需要建立与数据库的连接,然后通过该连接发送SQL给数据库执行,数据库执行完成之后,通过该连接返回执行结果。所以在Mybatis设计当中,需要完成数据库相关概念的抽象定义,包括SQL语句对象的定义,SQL执行器的定义,SQL执行结果的定义,以及基于JDBC完成实际的SQL执行,通过在Mybatis内部实现这些定义,从而做到SQL执行过程对应用程序的透明化,应用程序只需根据业务需求定义SQL即可,不需要关注SQL的执行以及获取结果的过程,只需要调用mapper接口的方法获取该方法返回结果即可。
Mybatis与Spring的关系
- Mybatis可以不依赖Spring单独使用,不过在基于Spring的企业级应用开发当中,一般需要基于mybatis提供的mybatis-spring包,将Mybatis融入到Spring的设计当中,从而可以将相关类交给Spring管理。
- 由于Spring只能对其Spring容器内的bean执行依赖注入,所以需要将mapper接口生成bean对象注册到spring容器,这样可以在DAO中直接注入mapper接口对应的bean对象,然后调用其方法来完成对其关联SQL的调用。