动态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="字符串" 判断条件的对 ...
随机推荐
- Mysql时间戳函数
1.转换为时间戳 select unix_timestamp('2013-07-15 10-06-07') 如果参数为空,则为当前时间 2.转换为时间 select from_unixtime(tim ...
- Core Java Volume I — 4.4. Static Fields and Methods
4.4. Static Fields and MethodsIn all sample programs that you have seen, the main method is tagged w ...
- ZSDRM001-发货清单
REPORT ZSDRM001 LINE-SIZE 225 LINE-COUNT 65 NO STANDARD PAGE HEADING.*------------------------------ ...
- 关于项目中用到的流程的sql和表
select * from FLOW_MAIN SEQCODE FULL_NAME SHORT_NAME FLOW_DESC CREATE_TIME UPDATE_TIME 1 CoursePackF ...
- OpenCV图像Surf与flann特征点(转载)
Surf(Speed Up Robust Feature) Surf算法的原理 ...
- 209. Minimum Size Subarray Sum
Given an array of n positive integers and a positive integer s, find the minimal length of a subarra ...
- JS初学之-代码精简思路
1.差不多的代码,观察其不一样的地方,使用变量存起来,方便替代. 2.将其存入函数之中方便调用.
- java日期类型转换总结date timestamp calendar string
用Timestamp来记录日期时间还是很方便的,但有时候显示的时候是不需要小数位后面的毫秒的,这样就需要在转换为String时重新定义格式. Timestamp转化为String: S ...
- Windows Git+TortoiseGit简易使用教程
转载自 http://blog.csdn.net/jarelzhou/article/details/8256139 官方教程:http://tortoisegit.org/docs/tortoise ...
- 黑马程序员——JAVA基础之List集合
------- android培训.java培训.期待与您交流! ---------- Collection : |--List:元素是有序的,元素可以重复.因为该集合体系有索引. | ...