动态SQL之标签
本节主要讲了动态SQL的几个标签:where set trim
where: 检出where语句的最前面是否含有AND和一个空格 或者 or和一个空格 ,如果有的话删除
set: 检出set的最后是否有逗号 ,如果有,则清空
trim:可用来替换where和set
foreach:遍历集合(array,list,key)
CDATA:不支持标签,用于有<等需要<时
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>
<!-- && 不推荐记忆 << -->
<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>
<!-- && 不推荐记忆 << -->
<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之标签的更多相关文章
- Mybatis学习笔记之---动态sql中标签的使用
动态Sql语句中标签的使用 (一)常用标签 1.<if> if标签通常用于WHERE语句中,通过判断参数值来决定是否使用某个查询条件, 他也经常用于UPDATE语句中判断是否更新某一个字段 ...
- 动态SQL常用标签
动态 SQL 目的:为了摆脱在不同条件拼接 SQL 语句的痛苦 在不同条件在生成不同的SQL语句 本质上仍然是SQL语句,不过是多了逻辑代码去拼接SQL,只要保证SQL的正确性按照格式去排列组合 可以 ...
- 动态SQL各个标签作用以及注意事项详解
创建com.mybatis包,包含:UserMapper.xml和mybatis-config.xml UserMapper.xml代码: <?xml version="1.0&quo ...
- MyBatis动态SQL foreach标签实现批量插入
需求:查出给定id的记录: <select id="getEmpsByConditionForeach" resultType="com.test.beans.Em ...
- Mybatis 最强大的动态sql <where>标签
<select id="findActiveBlogLike" resultType="Blog"> SELECT * FROM BLOG WHER ...
- [刘阳Java]_MyBatis_动态SQL标签用法_第7讲
1.MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑. 2.MyBatis中用于实现动态SQL的元素主要有 if choose(when,otherwi ...
- Mybatis:缓存,动态SQL,注解SQL以及动态标签使用
1 转义字符 字符 转义 描述 < < 小于 <= <= 小于等于 > > 大于 >= >= 大于等于 <> <> 不等于 &a ...
- Mybatis系列全解(八):Mybatis的9大动态SQL标签你知道几个?提前致女神!
封面:洛小汐 作者:潘潘 2021年,仰望天空,脚踏实地. 这算是春节后首篇 Mybatis 文了~ 跨了个年感觉写了有半个世纪 ... 借着女神节 ヾ(◍°∇°◍)ノ゙ 提前祝男神女神们越靓越富越嗨 ...
- 【ibatis】IBatis的动态SQL的写法
Ⅰ .动态SQL的写法 开始 <dynamic 条件成立时前面要加的字符串 prepend ="字符串"> prepend="字符串" 判断条件的对 ...
随机推荐
- php求文件的相对路径
php转义字符的应用,\为转义字符需要转义为\\. <?php //求b相对a的路径 $a="d:\web\file\ab.php"; $b="d:\web\fil ...
- ARM异常中断处理
ARM异常中断处理 在ARM体系中,通常有以下3种方式控制程序的执行流程: 在正常程序执行过程中,每执行一条ARM指令,程序计数器寄存器(PC)的值加4个字节:每执行一条Thumb指令,程序计数器寄存 ...
- 正则表达式入门教程&&经典Javascript正则表达式(share)
前言 例子: ^.+@.+\\..+$ 这样的代码曾经多次把我自己给吓退过.可能很多人也是被这样的代码给吓跑的吧.继续阅读本文将让你也可以自由应用这样的代码. 正文 教程:正则表达式30分钟入门教程 ...
- Eclipse中Egit冲突解决
Eclipse中Egit冲突解决 Git 作为进来最流行的分布式版本控制软件来说应用的十分广泛.EGit就是一款Eclipse上的Git插件.在使用Egit提交项目时,有时会产生冲突,需要对代码进行m ...
- [转载]新功能:用微软的Live Writer离线写博文
原文地址:Writer离线写博文">新功能:用微软的Live Writer离线写博文作者:新浪博客 Writer离线写博文" title="[转载]新功能:用微软的 ...
- Base适配器
package com.baidu.base; import java.util.List; import com.baidu.vo.Mydata;import com.bwie.yd.R;impor ...
- 课堂所讲整理:输入输出流(I/O)2(修改版)
package org.hanqi.ex; import java.io.*; public class TestFile2 { public static void main(String[] ar ...
- python 核心编程第5章(习题)
1.标准类型运算符. 写一段脚本,输入一个测验成绩,根据下面的标准,输出他的评分成绩(A-F). #coding:utf8 a = raw_input() a = int(a) if (a > ...
- 关于form 上传文件时的小问题
平时的form一般写成这样: <form action=" " method="" id="" name=""&g ...
- VGG_19 train_vali.prototxt file
name: "VGG_ILSVRC_19_layer" layer { name: "data" type: "ImageData" ...