MyBatis

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.延时加载

延时加载是指要用到什么就查什么,在进行关联查询时,只有一个对象用到的属性会被查出来,用不到的就不进行查询

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值