2021.1.19Java面试题总结

Mybatis框架

1.#{}和${}的区别是什么?(1)

1.#{}传入的参数会被当作一个字符串,而${}传入的参数会直接显示生成在sql语句中。
2.#{}能防止sql注入,是使用PreparedStatement进行预编译的,而${}不能防止sql注入。

2.Xml映射文件中,除了常见的select|insert|updae|delete标签之外,还有哪些标签?(2)

<cache/>标签,给定命名空间的缓存配置。
<cache-ref/>标签,其他命名空间缓存配置的引用。
<resultMap/>标签,是最复杂也是最强大的元素,用来描述如何从数据库结果集中来加载对象。
<parameterMap/>标签,已废弃!老式风格的参数映射。内联参数是首选, 这个元素可能在将来被移除,这里不会记录。
<sql/>标签,可被其他语句引用的可重用语句块。
<include/>标签,引用标签的语句。
<selectKey/>标签,不支持自增的主键生成策略标签。

3.最佳实践中,通常一个Xml映射文件,都会写一个Dao接口与之对应,请问,这个Dao接口的工作原理是什么?Dao接口里的方法,参数不同时,方法能重载吗?(3)

Dao接口的工作原理是JDK动态代理,Mybatis运行时会使用JDK动态代理为Dao接口生成代理proxy对象,代理对象proxy会拦截接口方法,转而执行接口方法所对应的MappedStatement所代表的sql,然后将sql执行结果返回。Dao接口里的方法不能被重载。

4.简述Mybatis的插件运行原理,以及如何编写一个插件。(5)

在四大对象创建的时候:
1、每个创建出来的对象不是直接返回的,而是
interceptorChain.pluginAll(parameterHandler);
2、获取到所有的Interceptor(拦截器)(插件需要实现的接口);
调用interceptor.plugin(target);返回target包装后的对象
3、插件机制,我们可以使用插件为目标对象创建一个代理对象; AOP(面向切面)
我们的插件可以为四大对象创建出代理对象;
代理对象就可以拦截到四大对象的每一个执行;
编写插件:
实现Mybatis的Interceptor接口并复写intercept()方法,然后在给插件编写注解,指定要拦截哪一个接口的哪些方法即可,记住,别忘了在配置文件中配置你编写的插件。

5.Mybatis能执行一对一、一对多的关联查询吗?都有哪些实现方式,以及它们之间的区别。(9)

能,Mybatis不仅可以执行一对一、一对多的关联查询,还可以执行多对一,多对多的关联查询,多对一查询,其实就是一对一查询,只需要把selectOne()修改为selectList()即可;多对多查询,其实就是一对多查询,只需要把selectOne()修改为selectList()即可。
关联对象查询,有两种实现方式,一种是单独发送一个sql去查询关联对象,赋给主对象,然后返回主对象。另一种是使用嵌套查询,嵌套查询的含义为使用join查询,一部分列是A对象的属性值,另外一部分列是关联对象B的属性值,好处是只发一个sql查询,就可以把主对象和其关联对象查出来。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值