1. Mybatis中的Mapper接口上加的注解是什么? 该注解的具体作用请简单描述一下 ? Mybatis 中的常见注解, 除了这个还有哪些
答:声明当前类是mybatis中的Mapper接口,其次程序运行时,框架会自动生成接口的实现类对象(代理对象),并给交Spring的IOC容器管理,@Select,@Insert,@Delete,@Update
2. 动态SQL标签中的<if> <where>标签的作用是什么? 动态SQL具体的应用场景?
-
<where>
:只会在有成立的if条件时,才会插入WHERE子句,而且还会自动去除第一个条件前面多余的and/or。 -
<if>
:条件判断,在test属性中指定的条件成立时,才会拼接对应的SQL片段。
3. Mybatis中的 # 与 $ 的区别是什么 ?实际开发中推荐用哪个, 为什么 ? Mybatis中like模糊查询你们是怎么处理的?
#,是预处理指令,实际开发常用于#,会在预处理,从缓存区找数据,其次就是变成?占位符
$是字符拼接符,存在不安全行为,例如SQL注入
LIKE 模糊查询用的是字符串concat()函数
4. Mybatis的映射配置文件定义的规范是什么 ? 项目开发中,你们的SQL是基于注解方式开发的还是XML映射配置文件开发的。
同包同名的规则,其次在Resource中建立一个与Mapper接口中一样的一个包,并编写xml语句,
-
XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)
-
XML映射文件的namespace属性为Mapper接口全限定名一致
-
XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致。
使用Mybatis的注解方式,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用XML来配置映射语句,也就是将SQL语句写在XML配置文件中。