MyBatis基础面试题

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

 

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

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

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

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

 

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

 

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


      select order_id id, order_no orderno ,order_price price form orders where order_id=#{id};

 

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


       select * from orders where order_id=#{id}


 
        
        

        
        
        

 

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

 

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

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

 
    select * from foo where bar like #{value} 

 

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

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

    
    select * from foo where bar like "%"#{value}"%"

 

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中,每一个

 

第2种:    使用 @param 注解:

 

import org.apache.ibatis.annotations.param;

public interface usermapper {

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

}

 

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

 
  select id, username, hashedpassword 
        from some_table 
        where username = #{username} 
        and hashedpassword = #{hashedpassword} 

 

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的功能

你可能感兴趣的:(个人总结)