Mybatis设计原理与Hibernate,Spring的关系简述

Mybatis与Hibernate

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

Mybatis的设计原理简述

  1. Mybatis的设计当中,主要是使用一个格式为XML的mapper文件来维护SQL集合,然后一个mapper.xml文件映射到一个mapper接口,或者说每个mapper接口对应一个mapper的命名空间namespace,一般mapper接口的接口名与mapper.xml文件名相同,mapper接口的每个方法对应mapper.xml文件的一个完整SQL。在应用代码中,通常为在DAO中,通过调用这个mapper接口的方法来执行对应的SQL。
  2. 在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的调用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值