Mybatis与Hibernate,Spring的关系简述

版权声明:非商业目的可自由转载,转载请标明出处 https://blog.csdn.net/u010013573/article/details/87860795

Mybatis与Hibernate

  1. 两者的设计初衷都是对JDBC进行包装,使得应用代码可以基于OOP来进行SQL的相关操作,即应用代码中可以通过POJO的方法调用来执行指定的SQL;
  2. Hibernate:POJO和数据表的映射,自动生成SQL,应用代码不需要定义相关SQL,直接调用POJO的相关方法即可;
  3. Mybatis:POJO和SQL的映射,需要在应用代码中提供SQL,mybatis提供基于POJO的方法调用来执行指定的SQL。

Mybatis与Spring

  1. Mybatis的设计当中,主要是使用一个格式为XML的mapper文件来维护SQL集合,然后一个mapper.xml文件映射到一个mapper接口,一般mapper接口的接口名与mapper.xml文件名相同,mapper接口的每个方法对应mapper.xml文件的一个完整SQL。在应用代码中,通常为在DAO中,通过调用这个mapper接口的方法来执行对应的SQL。
  2. 在SQL执行过程中,首先需要建立与数据库的连接,然后通过该连接发送SQL给数据库执行,数据库执行完成之后,通过该连接返回执行结果。所以在Mybatis设计当中,需要完成数据库相关概念的抽象定义,包括SQL语句对象的定义,SQL执行器的定义,SQL执行结果的定义,以及基于JDBC完成实际的SQL执行。
  3. 将Mybatis融入Spring的设计当中,由于Spring只能对其Spring容器内的bean执行依赖注入,所以需要将mapper接口生成bean注册到spring容器,这样可以在DAO中直接注入mapper接口对应的bean,然后调用其方法来完成对其关联SQL的调用。

猜你喜欢

转载自blog.csdn.net/u010013573/article/details/87860795
今日推荐