(四)Mybatis 面试题

房东的猫 提交于 2020-03-10 13:52:51

Mybatis

86、Mybatis是什么?

mybatis是一个持久层ORM框架。它内部封装了jdbc,使得开发更简洁,更高效。
Mybatis使开发者只需要关注sql语句本身,简化JDBC操作,不需要在关注加载驱动、创建连接、处理SQL语句等繁杂的过程。
MyBatis可以通过xml或注解完成ORM映射关系配置。

87、Mybatis和JDBC的关系? (标红)

JDBC是Java提供的一个操作数据库的API; MyBatis是一个持久层ORM框架,底层是对JDBC的封装。
MyBatis对JDBC操作数据库做了一系列的优化:
(1)mybatis使用已有的连接池管理,避免浪费资源,提高程序可靠性。
(2)mybatis提供插件自动生成DAO层代码,提高编码效率和准确性。
(3)mybatis 提供了一级和二级缓存,提高了程序性能。
(4)mybatis使用动态SQL语句,提高了SQL维护。(此优势是基于XML配置)
(5)mybatis对数据库操作结果进行自动映射

88、什么是ORM?(标红)

ORM的全称是Object Relational Mapping,即对象关系映射。
描述的是对象和表之间的映射。操作Java对象,通过映射关系,就可以自动操作数据库。
在ORM关系中,数据库表对应Java中的类,一条记录对应一个对象,一个属性对应一个列。
常见的ORM框架:Mybatis、Hibernate

89、MyBatis的两种配置方式?

注解、XML 

90、Mybatis中#{}和${}的区别是什么?

1.#{}实现的是sql语句的预处理参数,之后再sql中用?号代替,使用时不需要关注数据类型,Mybatis自动实现数据类型的转换,并且可以防止SQL注入

2.${}实现的是sql语句的直接拼接,不做数据类型转换,需要自行判断数据类型,不能防止SQL注入

3.在某些特定情况下必须使用${},如:在分表存储的情况下,对哪张表的查询是不确定的,也就是sql语句不能写死,表明是动态的,查询条件是固定的
此时表明只能使用${}方式进行字符串拼接,这样:slect * from ${tableName} where id = #{id}

总结:#{}占位符,用于参数传递; ${}用于SQL拼接

91、使用Mybatis过程中当实体类中的属性名和表中的字段名不一样,怎么解决?(标红)

1. 通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致 
2.使用通用Mapper时,可以通过@Column注解设置
3.如果进行自定义查询,可以通过@Result进行设置

【了解】4.如果使用的xml配置,通过<resultMap>进行配置

92、模糊查询like语句该怎么写?

1.使用通用Mapper的Criteria进行like语句的拼凑
2.使用#{}占位符方式,参数前后拼凑%。(select * from t_user where username like #{username} ,username数据为""%jack%"")
【了解】3.使用${}字符串拼接方式,可能引发sql注入问题:select * from t_user where username like '%${username}%'

93、【了解】一个Xml映射文件,都会写一个Dao接口与之对应,这个Dao接口的工作原理是什么?

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

MappedStatement解释:MappedStatement维护了一条<select|update|delete|insert>节点的封装,包括了传入参数映射配置、执行的SQL语句、结果
映射配置等信息。如以下一个<select/>节点
<select id=""selectAuthorLinkedHashMap"" resultType=""java.util.LinkedHashMap"">
        select id, username from author where id = #{value}
</select>

94、编写了一个Dao接口,提供需要的方法,在方法添加对应的注解就可以完成对应的功能,工作原理是什么?

Dao接口在使用时,MyBatis创建接口对应的代理类。
在调用对应的方法时,执行的是代理类对应的方法。
代理类的方法上添加的注解完成增删改查的操作,如果是查询将结果封装到方法返回值类型声明的对象中。

95、使用Mybatis时Dao接口里的方法能重载吗?

不能重载的,
因为是全限定名+方法名的必须唯一。

96、Mybatis是如何进行分页的?

使用第三方分页助手:PageHelper
使用方式:
在将要执行查询sql语句之前使用分页助手:PageHelper.startPage(pageNum:页码, pageSize:每页显示数量);

97、Mybatis分页插件的原理是什么?

使用MyBatis插件(也称为拦截器)机制,对需要使用分页的功能进行增强。也就是重写SQL,根据不同的数据库生产不同的分页语句。
Mysql生成limit语句,Oracle借助rownum生产对应子查询语句。

98、Mybatis是如何将sql执行结果封装为目标对象的?(标红)

提供POJO和表之间的映射关系,查询结果就可以完成封装。
1.使用通用Mapper,需要在POJO上字段上使用@Column注解
2.如果是自定义查询,需要通过Dao接口里使用@Result注解
3.如果是xml,需要使用<resultMap>配置映射关系

99、Mybatis动态sql标签有那些?

动态SQL标签主要是基于XML进行配置的,在校主要学习的是注解,没有使用过XML。
不过注解也支持部分动态标签
@Select("
"<script> 
select * from user where 1=1  
<if test='username != null '> and username = #{username} </if>  
</script>"
")

100、【了解】Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复?

不同的Xml映射文件,如果配置了namespace,那么id可以重复;如果没有配置namespace,那么id不能重复。
MyBatis通过namespace+id来进行不同XML标识。

101、Mybatis与Hibernate区别在哪里?

Hibernate是全自动的ORM框架,也就是使用hibernate不用编写任何SQL语句。关联对象直接调用对应方法,可以自动完成数据的查询。

MyBatis封装了JDBC基本操作,但仍需要编写SQL语句,也称为半自动ORM框架。使用通过Mapper可以简化MyBatis单表操作,
多表仍需要自己编写SQL语句。


102、【了解】解释一下MyBatis中命名空间(namespace)的作用。

namespace用于标识不同的XML配置文件。这样不同xml文件中sql语句的id相同也不会有冲突。
注解开发没有类似要求,只要保证接口全限定名不同即可(包+类名)

103、【了解】MyBatis中的动态SQL是什么意思?

在xml配置文件,根据数据的不同,动态拼凑对应的SQL语句。
例如:
<if>用于处理条件成立时显示部分SQL语句
<where> 如果有条件就显示 where 子句,如果没有条件则不显示。


104、【了解】Mybatis的缓存机制

Mybatis的缓存机制分为一级缓存和二级缓存
1.一级缓存:一级缓存的作用域是sqlSession会话级,相当于JDBC的Connection连接。一级缓存默认开启,用户不能手动配置。
当在同一个sqlSession中执行两次相同的sql语句时,第一次执行完毕会将数据库中查询的数据写到缓存(内存),第二次查询
时会从缓存中获取数据,不再去底层数据库查询,从而提高查询效率;

2.二级缓存:二级缓存的作用域为同一个mapper的namespace,是跨sqlSession的,同一个namespace中不同的查询SQL可以从
二级缓存中命中。二级缓存默认关闭,但是可以通过配置进行开启。
二级缓存的对象必须序列化,例如:User对象必须实现Serializable接口。

Mybatis中,执行select时,查询数据会被缓存;当执行insert、update、delete等操作的时候,缓存则会被清除

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!