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. scrapy基础知识之 处理Redis里的数据:

    数据爬回来了,但是放在Redis里没有处理.之前我们配置文件里面没有定制自己的ITEM_PIPELINES,而是使用了RedisPipeline,所以现在这些数据都被保存在redis的xx:items ...

  2. zimg服务器图片数据迁移后,图片404异常的问题解决

    由于zimg特殊的图片存储结构及图片命名规则,其迁移数据应该当相当简单的,仅把对应的存储图片数据的文件夹复制即可.往往简单的东西总会有一些成本在里面,下面是我简单的迁移测试过程中遇到的一些问题,仅供参 ...

  3. ElementUI 简要源码解析——Basic篇

    Layout 布局 row 布局组件中的父组件,用于控制子组件.很简单的一个布局标签,主要通过 justify 和 align 控制子元素的对齐方式,使用 render 函数通过传入的 tag 属性控 ...

  4. secureCRT背景颜色

    secureCRT是我们常用的linux远程登录软件,某些情况下我们安装的secureCRT工具可能默认背景颜色为白色,使用时很容易造成眼睛的疲劳,网上有些教程也只是修改当前登录窗口背景颜色,新的连接 ...

  5. 7月18日刷题记录 二分答案跳石头游戏Getting

    通过数:1 明天就要暑假编程集训啦~莫名开心 今天做出了一道 二分答案题(好艰辛鸭) 1049: B13-二分-跳石头游戏(二分答案) 时间限制: 5 Sec  内存限制: 256 MB提交: 30  ...

  6. 洛谷 P1039 侦探推理

    题目:https://www.luogu.org/problemnew/show/P1039 分析: 这道题是一道有技术含量的模拟,我们主要是不要让计算机向人一样思考,只需要让他穷举变化的星期几和当罪 ...

  7. [leetcode] 234. Palindrome Linked List (easy)

    原题 回文 水题 function ListNode(val) { this.val = val; this.next = null; } /** * @param {ListNode} head * ...

  8. 客户端内嵌Vue页面

    目前很多应用都存在网页端和客户端形式,例如常用的:钉钉.微信等.按传统的开发形式,需要为客户端开发一套界面.基于当前Web应用可以利用三大前端框架和UI框架快速开发出各种酷炫的界面,于是出现了客户端嵌 ...

  9. sql注入篇2

    一.前言 上一篇:sql注入篇1 二.基于回显的注入类型判断 1.有结果的注入 例如下图: (sqlllab less-1)可以看到有正常结果返回,对于的利用方式就是老套路了,先order by查询出 ...

  10. 给hexo添加宠物

    开始 之前在博客园上看到,公告栏里有人竟然在养鱼,觉得很好玩!一直念念不忘的,于是就想着在hexo中也来养几只,因为我用的事Next的Muse主题,所以有一个非常合适的侧边栏,先来看看效果. 点击此处 ...