1.半自动和全自动的区别:
全自动指的是可以通过对象关系映射自动生成sql语句,完全不需要手写;
半自动是指只是自动生成sql的一部分,只能完成基本类型数据的映射,并不能自动完成从数据库到javabean类的自动映射,需要程序员手动指定
2.orm框架
orm是指从数据库到java类的映射,使用orm框架就可以灵活地使用sql语句,而不用我们自己去编写,我们只需要去操作映射的对象
3.动态sql主要用于多条件的查询,但又不知道具体到底有几个条件,这些条件分别是什么,如果使用普通的sql就很难完成这个需求,而如果使用动态sql就只需要在对应的标签写下sql语句和判断条件,mybatis就可以帮你根据条件拼接sql
一对一:一个对象只能跟另一个对象一一对应
一对多:一个对象能对应多个其他对象
多对多:类A的对象可以对应多个类B的对象,同样类B的对象也可以对应多个类A的对象
4.一级缓存:mybatis自动开启,是指使用同一个SqlSesion对象进行查询时,会先查询缓存中有没有对应的数据,如果没有再去数据库查,只要两次查询中有任意的增删改操作,一级缓存都会被清空
二级缓存:二级缓存是指在同一个SqlSessionFactory对象下的,只有当其创建的一个sqlsession对象使用完毕并关闭时,二级缓存才会生效,否则就使用一级缓存
5.mybatis和hibernate的区别
mybatis是半自动,hibernate是全自动
mybatis灵活性更高可以更方便地满足用户的需求,在sql的优化上优于hibernate
hibernate的可移植性远大于mybatis
hibernate的二级缓存需要在配置文件中设置是哪种缓存,在使用时会更安全,在检查到脏数据时会报错,而mybatis在使用二级缓存时需要更小心
mybatis是一个轻量级框架,学习 起来会更轻松,而hibernate的学习就需要花费更多时间
6.分页插件PageHelper
需要先在pom文件中导入插件,通过传入当前页码和每页的数据条数就能完成分页的工作
缺点:对逆向工程不是很适配,只能支持非条件查询
7.延时加载
延时加载是指要用到什么就查什么,在进行关联查询时,只有一个对象用到的属性会被查出来,用不到的就不进行查询