if+where: 用于查询操作,where标签可以智能判断是否添加and、or、where关键词
 示例:
 <select id="findByParam" resultType="com.accp.pojo.User">
  select * from user
  <where>
   <if test="gender!=null">
    gender=#{gender}
   </if>
   <if test="userName!=null">
    and userName like CONCAT('%',#{userName},'%')
   </if>
  </where>
 </select>

if+set: 用于更新操作,set标签可以智能判断每个if条件后是否添加","
 示例:
 <update id="updateUser" parameterType="com.accp.pojo.User">
  update user
  <set>
   <if test="userName != null">
    userName = #{userName},
   </if>
   <if test="phone != null">
    phone = #{phone},
   </if>
   <if test="address != null">
    address = #{address},
   </if>
   <if test="gender != null">
    gender = #{gender}
   </if>
  </set>
  where id = #{id}
 </update>

trim:
 prefix:前缀
 suffix:后缀
 prefixOverrides:自动判断子语句if前面的条件语句是否添加或不添加其值
    suffixOverrides:自动判断子语句if后边的条件语句是否添加或不添加其值
      示例:
 <update id="updateUser" parameterType="com.accp.pojo.User">
  update user
  <trim prefix="set " suffixOverrides="," suffix=" where id = #{id}" >
   <if test="userName != null">
    userName = #{userName},
   </if>
   <if test="phone != null">
    phone = #{phone},
   </if>
   <if test="address != null">
    address = #{address},
   </if>
   <if test="gender != null">
    gender = #{gender}
   </if>
  </trim>
 </update>

foreach: 更新操作,或者用在insql语句中
 collection:传进来的参数类型
     List集合写成:”list”;
    数组写成:”array”;
    其他复杂类型写成:参数使用map 这里写map的key
    item:临时变量(每一个迭代元素的别名)
    open:该语句以什么开始
    close:该语句以什么结束
    separator:多个迭代元素以什么分隔(符)
 示例:
 <select id="findByIds" resultType="com.accp.pojo.User">
  select * from user where id in
  <foreach collection="list" item="usreIds" open="(" separator="," close=")">
   #{usreIds}
  </foreach>
 </select>

<select id="getUserListById_array" resultType="com.accp.pojo.User">
  select * from  user where id in
  <foreach collection="array" item="ids" open="(" separator="," close=")">
   #{ids}
  </foreach>
 </select>

choose:一般使用在多个条件时只想查询其中一个
 when
 otherwise

示例:
 <select id="findByParams" resultType="com.accp.pojo.User">
  select * from user where 1=1
  <choose>
   <when test="userName!=null">
    and userName like CONCAT('%',#{userName},'%')
   </when>
   <when test="phone!=null">
    and phone = #{userName}
   </when>
   <otherwise>
    and address like CONCAT('%',#{address},'%')
   </otherwise>
  </choose>
 </select>

动态SQL查询的更多相关文章

  1. SQL Server-聚焦深入理解动态SQL查询(三十二)

    前言 之前有园友一直关注着我快点出SQL Server性能优化系列,博主我也对性能优化系列也有点小期待,本来打算利用周末写死锁以及避免死锁系列的接着进入SQL Server优化系列,但是在工作中长时间 ...

  2. SQL Server-聚焦sp_executesql执行动态SQL查询性能真的比exec好?

    前言 之前我们已经讨论过动态SQL查询呢?这里为何再来探讨一番呢?因为其中还是存在一定问题,如标题所言,很多面试题也好或者有些博客也好都在说在执行动态SQL查询时sp_executesql的性能比ex ...

  3. 一步步学Mybatis-怎么样实现动态SQL查询(6)

    上一章我们已经讲完了关于Mybatis的分页用法,其实MyBatis 还具有的一个强大的特性之一通常是它的动态 SQL 能力. 如果你有使用 JDBC 或其他 相似框架的经验,你就明白要动态的串联 S ...

  4. 获取动态SQL查询语句返回值(sp_executesql)

    在写存储过程时经常会遇到需要拼接SQL语句的情况,一般情况下仅仅是为了执行拼接后的语句使用exec(@sql)即可. 而今天的一个存储过程却需要获取动态SQL的查询结果. 需求描述:在某表中根据Id值 ...

  5. SQL Server 2012 - 动态SQL查询

    动态SQL的两种执行方式:EXEC @sql 和 EXEC sys.sp_executesql @sql DECLARE @c_ids VARCHAR(200) SET @c_ids ='1,2' - ...

  6. Mybatis中多个参数的问题&&动态SQL&&查询结果与类的对应

    ### 1. 抽象方法中多个参数的问题 在使用MyBatis时,接口中的抽象方法只允许有1个参数,如果有多个参数,例如: Integer updatePassword( Integer id, Str ...

  7. ibatis 中动态SQL查询和动态标签嵌套的使用

    ibatis 动态查询对于从事 Java EE 的开发人员来说,iBatis 是一个再熟悉不过的持久层框架了,在 Hibernate.JPA 这样的一站式对象 / 关系映射(O/R Mapping)解 ...

  8. mybatis 动态SQL查询总结

    背景 ××项目需要提供系统部分函数第三方调用接口,基于安全性和避免暴露数据库表信息的基础上进行函数接口的设计,根据第三方调用身份的权限提供某张表的自定义集合.本项目基于mybatis的持久层框架,支持 ...

  9. MyBatis 动态SQL查询,多条件,分页

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-/ ...

  10. SpringBoot中JPA使用动态SQL查询

    https://www.jianshu.com/p/f72d82e90948 可以重点关注方法二,把原生sql传入数据库去查询 好处是:更加灵活坏处是:拼接sql比较痛苦,也容易出问题,比如拼接的sq ...

随机推荐

  1. 二、JavaScript的语法

    目录: 1.变量:存储数据的容器 2.数据类型 3.string数据类型 4.number数据类型 5.boolean数据类型 6.数据类型的隐式转换 6.数据类型转换函数 7.特殊类型 8.算术运算 ...

  2. 判断小端大端(C实现)

    C程序中的大端小端概念可以参见上一篇文章 如何区分小端和大端.本文重点讨论如何用C程序来判断当前系统是大端还是小端. 判断大端小端的程序如下: #include <stdio.h> int ...

  3. Java编程思想:序列化深层部分

    import java.io.*; import java.util.ArrayList; import java.util.List; public class Test { public stat ...

  4. Your project specifies TypeScriptToolsVersion 2.3, but a matching compiler ...... 出现这种警告解决方式

  5. Golang 高效实践之并发实践context篇

    前言 在上篇Golang高效实践之并发实践channel篇中我给大家介绍了Golang并发模型,详细的介绍了channel的用法,和用select管理channel.比如说我们可以用channel来控 ...

  6. 个人永久性免费-Excel催化剂功能第79波-自动及手动备份功能,比Onedrive还好用

    在OFFICE365里,有个自动保存功能,可惜保存的地址是在Onedrive里,在中国国情下,备份十分卡顿,近乎难以忍受的慢.虽然现在收费性的网盘部分是可以有文件版本的备份功能,但也是繁琐且最要命的是 ...

  7. [剑指offer] 34. 第一个只出现一次的字符

    题目描述 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写). 一次遍历存储到哈希表 一次 ...

  8. 基站搭建与IMSI捕获

     写在前面 : 实验目的是为了教学交流,坚决抵制违法行为. 一.实验目的 搭建基于OpenBTS的基站,手机接入该基站,进行短信.语音等测试. 二.所用仪器 USRP B210 1台,天线2根,PC机 ...

  9. 上车时机已到--.NETCore是适应时代发展的雄鹰利剑

    上车时机已到--.NETCore是适应时代发展的雄鹰利剑 要起飞了 .NET Core 3.0-prevew7:https://dotnet.microsoft.com/download/dotnet ...

  10. Java中返回值定义为int类型的 方法return 1返回的是int还是Integer&&finally中return问题

    在Java中返回值定义为int类型的 方法return 1:中返回的是Integer值,在返回的时候基本类型值1被封装为Integer类型. 定义一个Test类,在异常处理try中和finally中分 ...