mybatis学习

mybatis学习:

一、jdbc存在的问题:

1.频繁创建链接,造成系统资源的浪费

2.sql语句死板,造成sql语句硬编码的问题

3.代码太繁琐,维护难。

 

二、mybatis学习改进

1.通过链接池改进了jdbc频繁创建链接,消耗系统资源的问题。

2.通过mapper动态代理的方式,来改进。(其实本人觉得更加麻烦了)

3.通过实现框架的规范,一定程度上方便了修改代码。

三、mybatis架构

1.SqlMapperConfig.xml核心配置文件

2.这个文件中的子文件mapper1.xml

3.SqlSessionFactory收集1,2中的配置原料,然后造Sqlsession

4.session中有executor负责执行Sql语句

5.executor中有MapperStatement,负责解析Sql语句为一个pojo对象

 

流程:mybatis中SqlSessionFactory根据配置文件来执行Sql语句,然后操作数据库。

 

问题:二级缓存和分布式缓存

四、mybatis与hibernate之间的区别

mybatis是一个不完全的ORM框架,因为hibernate通过对象实体关系映射,不用写相关的sql语句,直接有方法可以自动生成sql语句。而mybatis不一样,需要程序员手写sql语句,然后通过sqlsession来执行。

 

五、mybatis和hibernate之间的联系

mybatis有mapper动态代理的模式。个人觉得十分像hibernate的对象实体关系映射。

首先,mybatis要写相关对象的接口类,接口类中定义需要操作相关类的方法,注意是定义,而不是实现。然后方法映射到对象的xml文件中,xml文件中写对应的sql语句。最后通过sqlsession来解析这个实现接口类,动态的生成实现对象。。。

这样的话,就类似hibernate了,hibernate也是通过session来调用insert,select这些方法,只不过这些方法是hibernate来自己封装的,然后相关的sql语句由这些方法来封装,最后我们操作hibernate的时候,也是直接通过调用session中的insert,select等方法来生成相关的语句操作数据库。mybatis则是通过sqlsession来代理出一个实现类对象,这个实现类对象来调用自己接口类中自己声明的这些insert,select这些方法,并且这些方法和xml文件中自己写的sql语句映射,所以当调用这些方法的时候,其实本质上就是调用自己在xml文件中写的那些个sql语句。在接口类中声明的这些方法其实就是为xml文件中的sql语句起了个别名而已。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值