mybatis映射文件 和动态sql

目录

mybatis的映射文件规范

mybatis动态SQL


mybatis的映射文件规范

网址:入门_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>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值