当前位置: 首页 > news >正文

MyBatis之动态SQL

目录

一、<if>标签

二、<trim>标签

三、<where>标签

四、<set>标签

五、<foreach>标签


一、<if>标签

当我们在某个平台提交某些信息时,可能都会遇到这样的问题,有些信息是必填信息,有些信息是非必填信息,例如,使用CSDN发布博客时:

那么程序猿在不确定某个字段是否会被用户传入时,该如何拼接SQL呢?这就需要使用<if>标签来判断某个字段是否被用户输入

代码示例:

    <insert id="insertUser">insert into userinfo(username, password<if test="photo != null">,photo</if>) values(#{username}, #{password}<if test="photo != null">,#{photo}</if>)</insert>

单元测试代码:

    @Testvoid insertUser() {UserInfo userInfo = new UserInfo();userInfo.setUsername("apple");userInfo.setPassword("123");userInfo.setPhoto(null);int ret = userMapper.insertUser(userInfo);System.out.println(ret);}

代码执行结果:

可以看到,photo为空时,最终构造的SQL语句并没有拼接photo字段。 

注意: 

(1) <if>标签必须包含test属性,如果test属性中的内容为true,则执行<if>标签语句中的内容;如果为false,则不执行,此时数据库中该字段的值为默认值。

(2) <if>标签中判断的字段必须是可以为null的字段,如果判断的字段不允许为null,程序会在执行期间报错。


二、<trim>标签

如果所有字段都是非必填信息,那么就需要使用<trim>标签结合<if>标签,对多个字段都采取动态生成的方式。

代码示例:

    <insert id="insertUser2">insert into userinfo<trim prefix="(" suffix=")" suffixOverrides=","><if test="username!=null">username,</if><if test="password!=null">password,</if><if test="photo!=null">photo,</if></trim><trim prefix="values (" suffix=")" suffixOverrides=","><if test="username!=null">#{username},</if><if test="password!=null">#{password},</if><if test="photo!=null">#{photo},</if></trim></insert>

<trim>标签中的4个属性所表示的含义:

prefix:表示整个语句块以prefix的值作为前缀;

suffix:表示整个语句块以suffix的值作为后缀;

prefixOverrides:表示整个语句块要去掉的前缀;

suffixOverrides:表示整个语句块要去掉的后缀。

三、<where>标签

<where>标签需要配合<if>标签来使用,用来接收动态参数进行查询数据库操作。

代码示例:

    <select id="selectUsers" resultType="com.example.demo.model.UserInfo">select * from userinfo<where><if test="username != null">username=#{username}</if><if test="password != null">and password=#{password}</if></where></select>

注意:

(1) <where>标签会删除语句块的前缀内容(and);

(2) <where>标签中的字段如果都为null,那么就不会生成where关键字。

上述示例代码也可以使用<trim prefix="where" prefixOverrides="and">替换。 

四、<set>标签

<set>标签可以配合<if>标签,根据用户传入的参数来修改数据,用法和<where>标签类似。

代码示例:

    <update id="updateUser">update userinfo<set><if test="username != null">username=#{username},</if><if test="password != null">password=#{password},</if><if test="photo != null">photo=#{photo},</if></set>where id=#{id};</update>

注意:

(1) <set>标签会删除语句块的后缀内容(,);

(2) <set>标签中的字段如果都为null,那么就不会生成set关键字。

上述示例代码也可以使用<trim prefix="set" suffixOverrides=",">替换。

五、<foreach>标签

<foreach>标签用于对集合进行遍历,例如根据多个文章id删除文章。

代码示例:

    <delete id="deleteUsers">delete from userinfo where id in<foreach collection="list" open="(" close=")" item="id" separator=",">#{id}</foreach></delete>

<foreach>标签中的5个必要属性:

collection:集合的名称(对应方法中的集合的参数名);

item:遍历集合时,集合中每个对象的名字;

separator:每次遍历之间以什么字符串间隔;

open:语句块的前缀内容;

close:语句块的后缀内容。

用一段伪代码来解释上述5个属性:

http://www.lryc.cn/news/32650.html

相关文章:

  • SpringBoot(Tedu)—DAY01——环境搭建
  • 代理模式-大话设计模式
  • STM32定时器的编码器接口模式
  • Java方法的使用
  • Linux命令·nl
  • 排序模型:DIN、DINE、DSIN
  • 【C++】Clang-Format:代码自动格式化(看这一篇就够了)
  • Linux命令·more
  • 为什么 SaaS 公司依靠知识库来做对客户服务?
  • 后端必备之VUE基础【黑马程序员】
  • 现代HYUNDAI EDI需求分析
  • 数据库基本功之SQL的基本函数
  • 配置主机名与ip的映射关系
  • Spring Cache简单介绍和使用
  • ECCV 2022|面向精确的主动相机定位算法
  • web实现环形旋转、圆形、弧形、querySelectorAll、querySelector、clientWidth、sin、cos、PI
  • PyCharm+Python+Selenium自动化测试动态验证码识别
  • git版本回退简单记录
  • QT入门Display Widgets之QLine、QLcdNumber、QTextBrowser
  • Spring学习笔记
  • 数据的标准化处理
  • 性能优化|记一次线上OOM问题处理
  • Vue动态粒子特效插件(背景线条吸附动画)
  • 【Java 类】002-类、属性、方法、代码块
  • Ubuntu Linux 编译安装的基本步骤
  • day59反刍笔记
  • 【阅读笔记】你不知道的Javascript--强制类型转换4
  • 华为OD机试真题Python实现【有效子字符串】真题+解题思路+代码(20222023)
  • 上门按摩预约APP源码-东郊到家源码(开发,PHP,平台搭建)
  • STL讲解——模拟实现vector