本节主要讲了动态SQL的几个标签:where set trim

where: 检出where语句的最前面是否含有AND和一个空格 或者 or和一个空格 ,如果有的话删除

set: 检出set的最后是否有逗号 ,如果有,则清空

trim:可用来替换where和set

foreach:遍历集合(array,list,key)

CDATA:不支持标签,用于有<等需要&lt;时

where 和 if 条件查询

<select id="whereMore01" resultType="com.shxt.model.User">
  SELECT
  *
  FROM user
  <where>
    <if test="user_name!=null and user_name.length() >0">
      AND user_name like CONCAT(#{user_name},'%')
    </if>
    <!-- &amp;&amp; 不推荐记忆 &lt;< -->
    <if test="account!=null and account.length() > 0">
      AND account = #{account}
    </if>
    </where>
</select>

set 和 if 更新对象信息

<update id="update01" parameterType="com.shxt.model.User" >
  UPDATE user
  <set>
    <if test="account!=null">
      account =#{account},
    </if>
    <if test="password!=null">
      password = #{password},
    </if>
    <if test="user_name!=null">
      user_name =#{user_name},
    </if>

  </set>
  WHERE
  id = #{id}
</update>

trim替换

  替换条件查询where

<select id="whereMore02" resultType="com.shxt.model.User">
  SELECT
  *
  FROM user
  <trim prefix="WHERE" prefixOverrides="AND |OR ">
    <if test="user_name!=null and user_name.length() >0">
      AND user_name like CONCAT(#{user_name},'%')
    </if>
    <!-- &amp;&amp; 不推荐记忆 &lt;< -->
    <if test="account!=null and account.length() > 0">
      AND account = #{account}
    </if>
  </trim>
</select>

  替换更新操作set

<update id="update02" parameterType="com.shxt.model.User" >
  UPDATE user
  <trim prefix="set" suffixOverrides=",">
    <if test="account!=null">
      account =#{account},
    </if>
    <if test="password!=null">
      password = #{password},
    </if>
    <if test="user_name!=null">
      user_name =#{user_name},
    </if>
  </trim>
  WHERE
  id = #{id}
</update>

foreach遍历in(2,3,4,5)

<select id="collectionTest" resultType="User">

  select * from user where id in

  <foreach collection="list|array|key" index = "index" item="us" open="(" close=")" separator=",">

    #{us}

  </foreach>

</select>

CDATA:查询小于id的集合

  <![CDATA[

    select * from user where id < #{id}

  ]]>

动态SQL之标签的更多相关文章

  1. Mybatis学习笔记之---动态sql中标签的使用

    动态Sql语句中标签的使用 (一)常用标签 1.<if> if标签通常用于WHERE语句中,通过判断参数值来决定是否使用某个查询条件, 他也经常用于UPDATE语句中判断是否更新某一个字段 ...

  2. 动态SQL常用标签

    动态 SQL 目的:为了摆脱在不同条件拼接 SQL 语句的痛苦 在不同条件在生成不同的SQL语句 本质上仍然是SQL语句,不过是多了逻辑代码去拼接SQL,只要保证SQL的正确性按照格式去排列组合 可以 ...

  3. 动态SQL各个标签作用以及注意事项详解

    创建com.mybatis包,包含:UserMapper.xml和mybatis-config.xml UserMapper.xml代码: <?xml version="1.0&quo ...

  4. MyBatis动态SQL foreach标签实现批量插入

    需求:查出给定id的记录: <select id="getEmpsByConditionForeach" resultType="com.test.beans.Em ...

  5. Mybatis 最强大的动态sql <where>标签

    <select id="findActiveBlogLike" resultType="Blog"> SELECT * FROM BLOG WHER ...

  6. [刘阳Java]_MyBatis_动态SQL标签用法_第7讲

    1.MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑. 2.MyBatis中用于实现动态SQL的元素主要有 if choose(when,otherwi ...

  7. Mybatis:缓存,动态SQL,注解SQL以及动态标签使用

    1 转义字符 字符 转义 描述 < < 小于 <= <= 小于等于 > > 大于 >= >= 大于等于 <> <> 不等于 &a ...

  8. Mybatis系列全解(八):Mybatis的9大动态SQL标签你知道几个?提前致女神!

    封面:洛小汐 作者:潘潘 2021年,仰望天空,脚踏实地. 这算是春节后首篇 Mybatis 文了~ 跨了个年感觉写了有半个世纪 ... 借着女神节 ヾ(◍°∇°◍)ノ゙ 提前祝男神女神们越靓越富越嗨 ...

  9. 【ibatis】IBatis的动态SQL的写法

    Ⅰ .动态SQL的写法 开始 <dynamic 条件成立时前面要加的字符串 prepend ="字符串"> prepend="字符串" 判断条件的对 ...

随机推荐

  1. ci总结

    1.创建模型,在模型中加载$this->load->database();2.在模型中写入想实现的功能方法3.在控制器中加载辅助函数和模型,$this->load->model ...

  2. dede cms列表页调用文章简介(借鉴)

    {dede:list pagesize='8' infolen='50'}<a href="[field:arcurl/]">[field:title/][内容调用代码 ...

  3. CUDA 并行编程简介

    前言 并行就是让计算中相同或不同阶段的各个处理同时进行.目前有很多种实现并行的手段,如多核处理器,分布式系统等.本专题的文章将主要介绍使用 GPU 实现并行的方法.参考本专题文章前请务必搭建好 CUD ...

  4. spring学习笔记---第三方SDK(Rest API)和Jaskson的巧用

    前言: 其实我以前一直不懂电商, 以及电商中所涉及的业务概念. 对于SKU等名词, 觉得有些玄乎. 对其背后的数据模型, 也有莫名的未知恐惧感: 庞大而理不清头绪. 不过最近有机会接触了微商(有赞), ...

  5. 时空上下文视觉跟踪(STC)算法的解读与代码复现(转)

    时空上下文视觉跟踪(STC)算法的解读与代码复现 zouxy09@qq.com http://blog.csdn.net/zouxy09 本博文主要是关注一篇视觉跟踪的论文.这篇论文是Kaihua Z ...

  6. 图像处理之face morphing

    以前在论坛.微博经常看到一张脸,五官长得像A,脸型似乎又是B,觉得很有意思. 比如像这张图片.这张图片应该是网友用Photoshop完成的,他们取了郭大爷的五官,放在金元帅的脸上,在把边缘处理平滑. ...

  7. PHP新手入门1——表单

    注:本身是Android,Android之前是java.但公司后台PHP特别多.就好奇php后台是怎么通过一个url给我数据的(完全不懂php).于是就学呗.学习系列随笔第一人称是一个Android小 ...

  8. clientX,screenX,pageX,offsetX的异同 【转载】

    首先说明一下以上对象都是指javascript中的,不包含其他语言. pageX/pageY: 鼠标相对于整个页面的X/Y坐标.注意,整个页面的意思就是你整个网页的全部,比如说网页很宽很长,宽2000 ...

  9. GridView用法大全(转)

    http://www.cnblogs.com/sufei/archive/2010/03/27/1698590.html

  10. 2016 Hunan Province Programming Contest

    2016 Hunan Province Programming Contest A. 2016 题意 \(1 \le a \le n, 1 \le b \le m\) ,其中\(1 \le n,m \ ...