目录
mybatis的映射文件规范
1.XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)。
2.XML映射文件的namespace属性为Mapper接口全限定名一致。
3.XML映射文件中sql语句的id与Mapper 接口中的方法名一致,并保持返回类型一致。
使用Mybatis的注解,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用XML来配置映射语句。
2
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.itheima.mapper.EmpMapper">
<!-- 条件查询员工-->
<!-- resultType 单条记录可封装的类型全限定名-->
<select id="list" resultType="com.itheima.pojo.Emp">
select *
from emp
where
<if test="name !=null">
name like concat('%', #{name}, '%')
</if>
<if test="gender !=null">
and gender = #{gender}
</if>
<if test="begin !=null and end !=null">
and entrydate between #{begin} and #{end}
order by update_time desc
</if>
</select>
</mapper>
3
mybatis动态SQL
随着用户的输入或外部条件的变化而变化的sql语句,我们称为动态sql
一个查询条件根据姓名查询
根据姓名和gender查询
需要用到三个标签
<if>用于判断条件是否成立,使用test属性进行条件判断,如果条件为true,则拼接sql
<where> where元素只会在有内容的情况下才插入where子句,而且会自动去除子句的开头and或or
自动去除and并且判断该sql语句成立的条件
<where>
<if test="name !=null">
name like concat('%', #{name}, '%')
</if>
<if test="gender !=null">
and gender = #{gender}
</if>
<if test="begin !=null and end !=null">
and entrydate between #{begin} and #{end}
order by update_time desc
</if>
</where>
执行成功
<forEach>