- 1、#{}和${}的区别是什么?">1、#{}和${}的区别是什么?
- {}是 sql 的参数占位符,MyBatis 会将 sql 中的#{}替换为?号,在 sql 执行前会使用 PreparedStatement 的参数设置方法,按序给 sql 的?号占位符设置参数值,比如 ps.setInt(0, parameterValue),#{item.name}的取值方式为使用反射从参数对象中获取 item 对象的 name 属性值,相当于param.getItem().getName()。
- 2、Xml 映射文件中,除了常见的 select|insert|update|delete 标签之外,还有哪些标签?">2、Xml 映射文件中,除了常见的 select|insert|update|delete 标签之外,还有哪些标签?
- 3、最佳实践中,通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应,请问,这个 Dao 接口的工作原理是什么?Dao 接口里的方法,参数不同时,方法能重载吗?">3、最佳实践中,通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应,请问,这个 Dao 接口的工作原理是什么?Dao 接口里的方法,参数不同时,方法能重载吗?
- 4、MyBatis 是如何进行分页的?分页插件的原理是什么?">4、MyBatis 是如何进行分页的?分页插件的原理是什么?
- 5、简述 MyBatis 的插件运行原理,以及如何编写一个插件。">5、简述 MyBatis 的插件运行原理,以及如何编写一个插件。
- 6、MyBatis 执行批量插入,能返回数据库主键列表吗?">6、MyBatis 执行批量插入,能返回数据库主键列表吗?
- 7、MyBatis 动态 sql 是做什么的?都有哪些动态 sql?能简述一下动态 sql 的执行原理不?">7、MyBatis 动态 sql 是做什么的?都有哪些动态 sql?能简述一下动态 sql 的执行原理不?
- 8、MyBatis 是如何将 sql 执行结果封装为目标对象并返回的?都有哪些映射形式?">8、MyBatis 是如何将 sql 执行结果封装为目标对象并返回的?都有哪些映射形式?
- 9、MyBatis 能执行一对一、一对多的关联查询吗?都有哪些实现方式,以及它们之间的区别。">9、MyBatis 能执行一对一、一对多的关联查询吗?都有哪些实现方式,以及它们之间的区别。
- 10、MyBatis 是否支持延迟加载?如果支持,它的实现原理是什么?">10、MyBatis 是否支持延迟加载?如果支持,它的实现原理是什么?
- 11、MyBatis 的 Xml 映射文件中,不同的 Xml 映射文件,id 是否可以重复?">11、MyBatis 的 Xml 映射文件中,不同的 Xml 映射文件,id 是否可以重复?
- 12、MyBatis 中如何执行批处理?">12、MyBatis 中如何执行批处理?
- 13、MyBatis 都有哪些 Executor 执行器?它们之间的区别是什么?">13、MyBatis 都有哪些 Executor 执行器?它们之间的区别是什么?
- 14、MyBatis 中如何指定使用哪一种 Executor 执行器?">14、MyBatis 中如何指定使用哪一种 Executor 执行器?
- 15、MyBatis 是否可以映射 Enum 枚举类?">15、MyBatis 是否可以映射 Enum 枚举类?
- 16、MyBatis 映射文件中,如果 A 标签通过 include 引用了 B 标签的内容,请问,B 标签能否定义在 A 标签的后面,还是说必须定义在 A 标签的前面?">16、MyBatis 映射文件中,如果 A 标签通过 include 引用了 B 标签的内容,请问,B 标签能否定义在 A 标签的后面,还是说必须定义在 A 标签的前面?
- 17、简述 MyBatis 的 Xml 映射文件和 MyBatis 内部数据结构之间的映射关系?">17、简述 MyBatis 的 Xml 映射文件和 MyBatis 内部数据结构之间的映射关系?
- 18、为什么说 MyBatis 是半自动 ORM 映射工具?它与全自动的区别在哪里?">18、为什么说 MyBatis 是半自动 ORM 映射工具?它与全自动的区别在哪里?
- 19.Mybatis的一级、二级缓存
- 20.什么是MyBatis的接口绑定?有哪些实现方式?
- 21.使用MyBatis的mapper接口调用时有哪些要求?
- 21.Mybatis运行原理
1、#{}和${}的区别是什么?
答:
- ${}是 Properties 文件中的变量占位符,它可以用于标签属性值和 sql 内部,属于静态文本替换,比如${driver}会被静态替换为com.mysql.jdbc.Driver。
{}是 sql 的参数占位符,MyBatis 会将 sql 中的#{}替换为?号,在 sql 执行前会使用 PreparedStatement 的参数设置方法,按序给 sql 的?号占位符设置参数值,比如 ps.setInt(0, parameterValue),#{item.name}的取值方式为使用反射从参数对象中获取 item 对象的 name 属性值,相当于param.getItem().getName()。
2、Xml 映射文件中,除了常见的 select|insert|update|delete 标签之外,还有哪些标签?
答:还有很多其他的标签,
、 、 、 、 ,加上动态 sql 的 9 个标签,trim|where|set|foreach|if|choose|when|otherwise|bind等,其中为 sql 片段标签,通过 标签引入 sql 片段, 为不支持自增的主键生成策略标签。 3、最佳实践中,通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应,请问,这个 Dao 接口的工作原理是什么?Dao 接口里的方法,参数不同时,方法能重载吗?
注:这道题也是京东面试官面试我被问的。
答:Dao 接口,就是人们常说的Mapper接口,接口的全限名,就是映射文件中的 namespace 的值,接口的方法名,就是映射文件中MappedStatement的 id 值,接口方法内的参数,就是传递给 sql 的参数。Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为 key 值,可唯一定位一个MappedStatement,举例:com.mybatis3.mappers.StudentDao.findStudentById,可以唯一找到 namespace 为com.mybatis3.mappers.StudentDao下面id = findStudentById的MappedStatement。在 MyBatis 中,每一个、、 、 标签均会被解析为MappedStatement对象,标签内的 sql 会被解析为 BoundSql 对象。 18、为什么说 MyBatis 是半自动 ORM 映射工具?它与全自动的区别在哪里?
注:我出的
答:Hibernate 属于全自动 ORM 映射工具,使用 Hibernate 查询关联对象或者关联集合对象时,可以根据对象关系模型直接获取,所以它是全自动的。而 MyBatis 在查询关联对象或关联集合对象时,需要手动编写 sql 来完成,所以,称之为半自动 ORM 映射工具。19.Mybatis的一级、二级缓存
一级缓存: 基于 PerpetualCache 的 HashMap 本地缓存,其存储作用域为 Session,当 Session flush 或 close 之后,该 Session 中的所有 Cache 就将清空,默认打开一级缓存。
二级缓存与一级缓存其机制相同,默认也是采用 PerpetualCache,HashMap 存储,不同在于其存储作用域为 Mapper(Namespace),并且可自定义存储源,如 Ehcache。默认不打开二级缓存,要开启二级缓存,使用二级缓存属性类需要实现Serializable序列化接口(可用来保存对象的状态),可在它的映射文件中配置 ;
对于缓存数据更新机制,当某一个作用域(一级缓存 Session/二级缓存Namespaces)的进行了C/U/D 操作后,默认该作用域下所有 select 中的缓存将被 clear。20.什么是MyBatis的接口绑定?有哪些实现方式?
接口绑定,就是在MyBatis中任意定义接口,然后把接口里面的方法和SQL语句绑定, 我们直接调用接口方法就可以,这样比起原来了SqlSession提供的方法我们可以有更加灵活的选择和设置。
接口绑定有两种实现方式:
注解绑定,就是在接口的方法上面加上 @Select、@Update等注解,里面包含Sql语句来绑定;
外一种就是通过xml里面写SQL来绑定, 在这种情况下,要指定xml映射文件里面的namespace必须为接口的全路径名。当Sql语句比较简单时候,用注解绑定, 当SQL语句比较复杂时候,用xml绑定,一般用xml绑定的比较多。21.使用MyBatis的mapper接口调用时有哪些要求?
Mapper接口方法名和mapper.xml中定义的每个sql的id相同;
Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的parameterType的类型相同;
Mapper接口方法的输出参数类型和mapper.xml中定义的每个sql的resultType的类型相同;
Mapper.xml文件中的namespace即是mapper接口的类路径。21.Mybatis运行原理
1.流程图
2..文字解释
1.先通过Resources加载全局配置文件.下面需要实例化SqlSessionFactoryBuilder构建器.帮助
接口实现类DefaultSqlSessionFactory.
2.在实例化DefaultSqlSessionFactory之前需要先创建XmlConfigBuilder解析全局配置文件流,并把解析结果存放在Configuration中.之后把Configuratin传递给DefaultSqlSessionFactory.到此SqlSessionFactory工厂创建成功.
3.由SqlSessionFactory工厂创建SqlSession.
4.每次创建SqlSession时,都需要由TransactionFactory创建Transaction对象,同时还需要创建SqlSession的执行器Excutor,最后实例化DefaultSqlSession,传递给SqlSession接口.
5.根据项目需求使用SqlSession接口中的API完成具体的事务操作.
6.如果事务执行失败,需要进行rollback回滚事务.
7.如果事务执行成功提交给数据库.关闭SqlSession