MyBatis面试专题及答案

VIP免费
2024-12-11
1
0
266.09KB
7 页
5.9玖币
侵权投诉
1、什么是 MyBatis?
答:MyBatis 是一个可以自定义 SQL、存储过程和高级映射的持久层框架。
2、讲下 MyBatis 的缓存
答:MyBatis 的缓存分为一级缓存和二级缓存,一级缓存放在 session 里面,默认就有,二级缓
存放在它的命名空间里,默认是不打开的,使用二级缓存属性类需要实现 Serializable 序列化
接口(可用来保存对象的状态),可在它的映射文件中配置<cache/>
3、Mybatis 是如何进行分页的?分页插件的原理是什么?
答:
1)Mybatis 使用 RowBounds 对象进行分页,也可以直接编写 sql 实现分页,也可以使用
Mybatis 的分页插件。
2)分页插件的原理:实现 Mybatis 提供的接口,实现自定义插件,在插件的拦截方法内拦
截待执行的 sql,然后重写 sql。
举例:select * from student,拦截 sql 后重写为:select t.* from (select * from student)t
limit 0,10
4、简述 Mybatis 的插件运行原理,以及如何编写一个插件?
答:
1)Mybatis 仅可以编写针对 ParameterHandler、ResultSetHandler、StatementHandler、
Executor 这4种接口的插件,Mybatis 通过动态代理,为需要拦截的接口生成代理对象以实
现接口方法拦截功能,每当执行这 4种接口对象的方法时,就会进入拦截方法,具体就是
InvocationHandler 的invoke()方法,当然,只会拦截那些你指定需要拦截的方法。
2)实现 Mybatis 的Interceptor 接口并复写 intercept()方法,然后在给插件编写注解,指定
要拦截哪一个接口的哪些方法即可,记住,别忘了在配置文件中配置你编写的插件。
5、Mybatis 动态 sql 是做什么的?都有哪些动态 sql?能简述一下动态 sql 的执行原理不?
答:
1)Mybatis 动态 sql 可以让我们在 Xml 映射文件内,以标签的形式编写动态 sql,完成逻辑
判断和动态拼接 sql 的功能。
2)Mybatis 提供了 9种动态 sql 标签:
trim|where|set|foreach|if|choose|when|otherwise|bind。
3)其执行原理为,使用 OGNL 从sql 参数对象中计算表达式的值,根据表达式的值动态拼
接sql,以此来完成动态 sql 的功能。
6、#{}和${}的区别是什么?
答:
1)#{}是预编译处理,${}是字符串替换。
2)Mybatis 在处理#{}时,会将 sql 中的#{}替换为?号,调用 PreparedStatement 的set 方法
来赋值;
3)Mybatis 在处理${}时,就是把${}替换成变量的值。
4)使用#{}可以有效的防止 SQL 注入,提高系统安全性。
7、为什么说 Mybatis 是半自动 ORM 映射工具?它与全自动的区别在哪里?
答:Hibernate 属于全自动 ORM 映射工具,使用 Hibernate 查询关联对象或者关联集合对象
时,可以根据对象关系模型直接获取,所以它是全自动的。而 Mybatis 在查询关联对象或
关联集合对象时,需要手动编写 sql 来完成,所以,称之为半自动 ORM 映射工具。
8、Mybatis 是否支持延迟加载?如果支持,它的实现原理是什么?
答:
1)Mybatis 仅支持 association 关联对象和 collection 关联集合对象的延迟加载,association
指的就是一对一,collection 指的就是一对多查询。在 Mybatis 配置文件中,可以配置是否
启用延迟加载 lazyLoadingEnabled=true|false。
2)它的原理是,使用 CGLIB 创建目标对象的代理对象,当调用目标方法时,进入拦截器方
法,比如调用 a.getB().getName(),拦截器 invoke()方法发现 a.getB()是null 值,那么就会单
独发送事先保存好的查询关联 B对象的 sql,把 B查询上来,然后调用 a.setB(b),于是 a的
对象 b属性就有值了,接着完成 a.getB().getName()方法的调用。这就是延迟加载的基本原
理。
9、MyBatis 与Hibernate 有哪些不同?
答:
1)Mybatis 和hibernate 不同,它不完全是一个 ORM 框架,因为 MyBatis 需要程序员自己
编写 Sql 语句,不过 mybatis 可以通过 XML 或注解方式灵活配置要运行的 sql 语句,并将
java 对象和 sql 语句映射生成最终执行的 sql,最后将 sql 执行的结果再映射生成 java 对
象。
2)Mybatis 学习门槛低,简单易学,程序员直接编写原生态 sql,可严格控制 sql 执行性
能,灵活度高,非常适合对关系数据模型要求不高的软件开发,例如互联网软件、企业运
营类软件等,因为这类软件需求变化频繁,一但需求变化要求成果输出迅速。但是灵活的
前提是 mybatis 无法做到数据库无关性,如果需要实现支持多种数据库的软件则需要自定
义多套 sql 映射文件,工作量大。
3)Hibernate 对象/关系映射能力强,数据库无关性好,对于关系模型要求高的软件(例如
需求固定的定制化软件)如果用 hibernate 开发可以节省很多代码,提高效率。但是
Hibernate 的缺点是学习门槛高,要精通门槛更高,而且怎么设计 O/R 映射,在性能和对象
摘要:
展开>>
收起<<
1MyBatisMyBatisSQL2!"MyBatis#MyBatis#$%#&#,#'(session)*,+,-.,&#'(/0123),+,456,78	:;?Serializable@ABCD(8EFGHIJ),(/KLMNO3MybatisPQRS$T$TULVW1XMybatis78RowBoundsGHRS$TYZ[C\]sql>?$TYZ78Mybatis$TUL2X$TULVW>?Mybatis^_CDY>?ULY(UL`a...
声明:本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。玖贝云文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知玖贝云文库,我们立即给予删除!
分类:计算机
价格:5.9玖币
属性:7 页
大小:266.09KB
格式:PDF
时间:2024-12-11
作者详情
-
IMU2CLIP MULTIMODAL CONTRASTIVE LEARNING FOR IMU MOTION SENSORS FROM EGOCENTRIC VIDEOS AND TEXT NARRATIONS Seungwhan Moon Andrea Madotto Zhaojiang Lin Alireza Dirafzoon Aparajita Saraf5.9 玖币0人下载
-
Improving Visual-Semantic Embedding with Adaptive Pooling and Optimization Objective Zijian Zhang1 Chang Shu23 Ya Xiao1 Yuan Shen1 Di Zhu1 Jing Xiao25.9 玖币0人下载