mybatis面试题

1、#{}和${}的区别是什么?

#{}是预编译处理,${}是字符串替换。

Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;

Mybatis在处理${}时,就是把${}替换成变量的值。

使用#{}可以有效的防止SQL注入,提高系统安全性。

2、当实体类中的属性名和表中的字段名不一样 ,怎么办 ?

第1种: 通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致

复制

第2种: 通过来映射字段名和实体类属性名的一一对应的关系



 
         
         

         
         
         

复制

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

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

string wildcardname = “%smi%”; 
list names = mapper.selectlike(wildcardname);

复制

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

string wildcardname = “smi”; 
    list names = mapper.selectlike(wildcardname);

    

复制

4、通常一个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中,每一个 select * fromuser_user_t whereuser_name = #{0} anduser_area=#{1}

复制

第2种: 使用 @param 注解:

import org.apache.ibatis.annotations.param;

public interface usermapper {

    user selectuser(@param(“username”) string username,@param(“hashedpassword”) string hashedpassword);

}

复制

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

复制

10、Mybatis动态sql是做什么的?都有哪些动态sql?能简述一下动态sql的执行原理不?Mybatis动态sql可以让我们在Xml映射文件内,以标签的形式编写动态sql,完成逻辑判断和动态拼接sql的功能。

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

其执行原理为,使用OGNL从sql参数对象中计算表达式的值,根据表达式的值动态拼接sql,以此来完成动态sql的功能。

你可能感兴趣的:(mybatis,sql,java)