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语句起了个别名而已。