Mybatis最全的高质量面试题和答案—2

Posted 四猿外

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis最全的高质量面试题和答案—2相关的知识,希望对你有一定的参考价值。

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

第1 种: 在Java 代码中添加sql 通配符。

string wildcardname = “%smi%”;
list<name> names = mapper.selectlike(wildcardname);
<select id=”selectlike”>
select * from foo where bar like #{value}
</select>

第2 种: 在sql 语句中拼接通配符,会引起sql 注入

string wildcardname = “smi”;
list<name> names = mapper.selectlike(wildcardname);
<select id=”selectlike”>
select * from foo where bar like "%"#{value}"%"
</select>

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

Dao 接口即Mapper 接口。接口的全限名,就是映射文件中的namespace 的值;接口的方法名,就是映射文件中Mapper 的Statement 的id 值; 接口方法内的参数,就是传递给sql 的参数。

Mapper 接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key 值, 可唯一定位一个MapperStatement。在Mybatis 中, 每一个<select>、<insert>、<update>、<delete>标签,都会被解析为一个MapperStatement 对象。

举例:com.mybatis3.mappers.StudentDao.findStudentById,可以唯一找到namespace 为com.mybatis3.mappers.StudentDao 下面id 为findStudentById 的MapperStatement。

Mapper 接口里的方法,是不能重载的,因为是使用全限名+方法名的保存和寻找策略。Mapper 接口的工作原理是JDK 动态代理,Mybatis 运行时会使用JDK动态代理为Mapper 接口生成代理对象proxy,代理对象会拦截接口方法,转而执行MapperStatement 所代表的sql,然后将sql 执行结果返回。

10、Mybatis 是如何进行分页的?分页插件的原理是什么?

Mybatis 使用RowBounds 对象进行分页,它是针对ResultSet 结果集执行的内存分页,而非物理分页。可以在sql 内直接书写带有物理分页的参数来完成物理分页功能, 也可以使用分页插件来完成物理分页。

分页插件的基本原理是使用Mybatis 提供的插件接口, 实现自定义插件, 在插件的拦截方法内拦截待执行的sql,然后重写sql,根据dialect 方言,添加对应的物理分页语句和物理分页参数。

11、Mybatis 是如何将sql 执行结果封装为目标对象并返回的?都有哪些映射形式?

第一种是使用标签,逐一定义数据库列名和对象属性名之间的映射关系。

第二种是使用sql 列的别名功能,将列的别名书写为对象属性名。有了列名与属性名的映射关系后,Mybatis 通过反射创建对象,同时使用反射给对象的属性逐一赋值并返回,那些找不到映射关系的属性, 是无法完成赋值的。

12、如何执行批量插入?

首先,创建一个简单的insert 语句:

<insert id=”insertname”>
insert into names (name) values (#{value})
</insert>

然后在java 代码中像下面这样执行批处理插入:

list < string > names = new arraylist();
names.add(“fred”);
names.add(“barney”);
names.add(“betty”);
names.add(“wilma”);
// 注意这里executortype.batch
sqlsession sqlsession =
sqlsessionfactory.opensession(executortype.batch);
try {
namemapper mapper = sqlsession.getmapper(namemapper.class);
for (string name: names) {
mapper.insertname(name);
}
sqlsession.commit();
} catch (Exception e) {
e.printStackTrace();
sqlSession.rollback();
throw e;
}
finally {
sqlsession.close();
}

13、如何获取自动生成的(主)键值?

insert 方法总是返回一个int 值,这个值代表的是插入的行数。

如果采用自增长策略,自动生成的键值在insert 方法执行完后可以被设置到传入的参数对象中。

示例:

<insert id=”insertname” usegeneratedkeys=”true” keyproperty=”
id”>
insert into names (name) values (#{name})
</insert>
name name = new name();
name.setname(“fred”);
int rows = mapper.insertname(name);
// 完成后,id 已经被设置到对象中
system.out.println(“rows inserted = ” + rows);
system.out.println(“generated key value = ” + name.getid());

14、在mapper 中如何传递多个参数?

1、第一种:DAO 层的函数

public UserselectUser(String name,String area);

对应的xml,#{0}代表接收的是dao 层中的第一个参数,#{1}代表dao 层中第二参数,更多参数一致往后加即可。

<select id="selectUser"resultMap="BaseResultMap">
select * fromuser_user_t whereuser_name = #{0}
anduser_area=#{1}
</select>

2、第二种: 使用@param 注解:

public interface usermapper {
user selectuser(@param(“username”) string
username,@param(“hashedpassword”) string hashedpassword);
}

然后,就可以在xml 像下面这样使用(推荐封装为一个map,作为单个参数传递给mapper):

<select id=”selectuser” resulttype=”user”>
select id, username, hashedpassword
from some_table
where username = #{username}
and hashedpassword = #{hashedpassword}
</select>

3、第三种:多个参数封装成map

try {
//映射文件的命名空间.SQL 片段的ID,就可以调用对应的映射文件中的
SQL
//由于我们的参数超过了两个,而方法中只有一个Object 参数收集,因此
我们使用Map 集合来装载我们的参数
Map < String, Object > map = new HashMap();
map.put("start", start);
map.put("end", end);
return sqlSession.selectList("StudentID.pagination", map);
} catch (Exception e) {
e.printStackTrace();
sqlSession.rollback();
throw e;
} finally {
MybatisUtil.closeSqlSession();
}

15、Mybatis 动态sql 有什么用?执行原理?有哪些动态sql?

Mybatis 动态sql 可以在Xml 映射文件内,以标签的形式编写动态sql,执行原理是根据表达式的值完成逻辑判断并动态拼接sql 的功能。

Mybatis 提供了9 种动态sql 标签:trim | where | set | foreach | if | choose
| when | otherwise | bind。

以上是关于Mybatis最全的高质量面试题和答案—2的主要内容,如果未能解决你的问题,请参考以下文章

Mybatis最全的高质量面试题和答案—5

Mybatis最全的高质量面试题和答案—1

Mybatis最全的高质量面试题和答案—4

最全MySQL面试60题和答案

最全MySQL面试60题和答案

最全BAT面试239道题答案:Map集合题+并发+中间件+MySQL等