记Mybatis动态sql
记MyBatis动态SQL
写在前面:
在此记录下项目中能够经常遇到的MyBatis动态SQL,因为经常容易忘,所以索性就给记录下来,免得每次都要百度搜索好久,需要使用的朋友自取,但是别忘了点赞哦
在此仅作部分说明和XML文件演示:
1.< SQL >标签
又叫 共性抽取
<!--<sql>一般放在上面或最底下-->
<sql id="person">
id
,name,sex
</sql>
<select id="queryPerson" resultType="Person">
SELECT
<!--在此调用sql的id-->
<include refid="person"></include>
FROM person
</select>
2.< if >标签
在test中写判断条件,< if >中只能用and不能用&&,并且,避免连接时and/or出错,上面最好用 < where >或者 where 1=1拼接
< where >可以代替where 1=1 并且能自动去除掉第一个and
<select id="queryPerson" resultType="Person">
SELECT * FROM Person WHERE 1=1
<if test="name!=null and param1!=''">
and name=#{name}
</if>
</select>
3.分支标签
即分支语法,与switch case ,if-else相近
1.第一种:用在查询条件上用choose-when;otherwise可不要
<select id="queryPerson" resultType="Person">
SELECT * FROM person
<where>
<choose>
<when test="name !=null">
name = #{name}
</when>
<when test="age !=null">
age = #{age}
</when>
<otherwise>
sex = #{sex}
</otherwise>
</choose>
</where>
2. 第二种case-when:用在查询结果上
<select id="queryPerson" resultType="Person">
SELECT id,name,
<!--sex可省-->
( case sex
when 1 then "男"
when 2 then "女"
ELSE "中性人" end) as sex
FROM person
</select>
3.case-when 的特殊用法:行转列:
原本:
id | name | subject | score |
---|---|---|---|
1 | 张三 | JAVA | 90 |
2 | 张三 | VUE | 66 |
3 | 李四 | VUE | 80 |
4 | 王五 | XML | 70 |
转换后:
name | JAVA | VUE | XML |
---|---|---|---|
张三 | 90 | 66 | null |
李四 | null | 80 | null |
张三 | null | null | 70 |
SELECT
name,
SUM(CASE subject WHEN 'JAVA' THEN score end) as 'JAVA',
SUM(CASE subject WHEN 'VUE' THEN score end) as 'VUE',
SUM(CASE subject WHEN 'XML' THEN score end) as 'XML'
FROM prson
GROUP BY name
< foreach >标签
foreach标签一般用来遍历查询或者批量操作
注:
collection中写列表名,
open表示语句前面用( 包含,close表示后面用 )包含,也可自行添加括号
separator表示中间用 ,隔开,
item表示每个list中的字符或者对象名,如果是array数组,item.id可写为id
index 表示下标,可省略
遍历list
1.批量查询列表
<select id="queryList" resultType="Person">
SELECT *
FROM person
WHERE person.id
IN
<foreach collection="list" open="(" close=")"separator="," item="item">
#{item.id}
</foreach>
</select>
- 批量插入列表:
<insert id="insertBatch">
INSERT INTO person (id,name)
VALUES
<foreach collection="list" item="item" separator=",">
(
#{item.id},
#{item.name}
)
</foreach>
</insert>
3.批量修改列表
<update id="updateBatch">
UPDATE person
SET age = '18'
WHERE
sex = '男'
AND name IN
<foreach collection="nameList" item="item" index="index" open="(" close=")" separator=",">
#{item.name}
</foreach>
</update>
4.批量删除列表
<delete id="deleteBatch">
DELETE FROM person
WHERE id IN
<foreach collection="list" item="item" separator="," open="(" close=")">
#{item.id}
</foreach>
</delete>
遍历map
1.map 的entrySet()
<insert id="insertPersonMap" parameterType="java.util.Map">
INSERT INTO person(id, name)
VALUES
<foreach collection="map.entrySet()" open="(" separator="," close=")" index="key" item="val">
#{key}, #{val}
</foreach>
</insert>
2.分别遍历
<insert id="insertPersonMap" parameterType="java.util.Map">
INSERT INTO person
<foreach collection="map.keys" item="key" open="(" separator="," close=")">
#{key}
</foreach>
VALUES
<foreach collection="param.value" item="val" open="(" separator="," close=")">
#{val}
</foreach>
</insert>
3.map中值为list[map]的遍历:
参数形式:
{"k1":"v1",
"k2":[
{"a1":"b1"},
{"a2":"b2"}
]
}
遍历方式(双重):
<foreach collection="Map" item="item" separator="," >
<foreach collection="item.entrySet()" separator="," index="key" item="val">
#{key} #{val}
</foreach>
</foreach>
关系映射 resultMap
一般情况:
<!--使用resultMap手动映射-->
<resultMap id="personMap" type="person">
<!--主键绑定-->
<id property="id" column="person.id"></id>
<!--非主键绑定-->
<result property="name" column="person.name"></result>
</resultMap>
list嵌套等
<resultMap id="ListMap" type="路径.person">
<result column='id' property='id' />
<result column='name' property='name' />
<collection property='实体中的list名' resultMap='listResultMap'/>
</resultMap>
<resultMap id="listResultMap" type="list中装的数据类型路径">
<result column='id' property='id' />
<result column='name' property='name' />
</resultMap>
嵌套查询
需要返回list的同时还要返回list中对象包含的list
<!--设定映射关系-->
<resultMap id="personMap" type="com.personList">
<id column="ID" property="id"/>
<result column="NAME" property="name"/>
<result column="TYPE" property="type"/>
<collection property="scoreList" select="queryscoreList" column="{personId=id}"></collection>
</resultMap>
<resultMap id="scoreListMap" type="com.scoreList">
<id column="ID" property="id"/>
<result column="PERSON_ID" property="personId"/>
<result column="SCORE" property="score"/>
</resultMap>
<!--编写语句-->
<select id="selectPersonList" resultMap="personMap">
SELECT
ID,
NAME`,
FROM person
</select>
<!--因为关联了映射关系,下面语句会自动执行并添加进list中-->
<select id="queryScoreList" resultMap="scoreListMap">
SELECT score from score表
</select>
补充:collection 与assocation的异同
异:
关联-association
集合-collection
即assocation是一对一的关系,collection是一对多的关系
< collection >比< association >多了一个ofType属性,
即collection集合中单个元素的javaType属性
< collection >的javaType属性是继承了Collection接口的list或set等java集合属性
同:
< collection >和< association >标签都属于嵌套结果集,
处理逻辑基本相同
其他重要sql笔记
concat拼接:
两个字段拼接起来搭建新的一列
或合并字符(例如:id,%)或字符串
select
concat(id,name) as id_name
from person
时间比较:
符号转换:避免出现奇怪的bug
< | <= | > | >= | & | ' | " |
---|---|---|---|---|---|---|
< ; | < ;= | > ; | > ;= | & ; | &apos ; | " ; |
(unix_timestamp(START_TIME) <=unix_timestamp(NOW()))
记Mybatis动态sql的更多相关文章
- mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句
mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...
- 9.mybatis动态SQL标签的用法
mybatis动态SQL标签的用法 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...
- 自己动手实现mybatis动态sql
发现要坚持写博客真的是一件很困难的事情,各种原因都会导致顾不上博客.本来打算写自己动手实现orm,看看时间,还是先实现一个动态sql,下次有时间再补上orm完整的实现吧. 用过mybatis的人,估计 ...
- Mybatis动态SQL单一基础类型参数用if标签
Mybatis动态SQL单一基础类型参数用if标签时,test中应该用 _parameter,如: 1 2 3 4 5 6 <select id="selectByName" ...
- 超全MyBatis动态SQL详解!( 看完SQL爽多了)
MyBatis 令人喜欢的一大特性就是动态 SQL. 在使用 JDBC 的过程中, 根据条件进行 SQL 的拼接是很麻烦且很容易出错的. MyBatis 动态 SQL 的出现, 解决了这个麻烦. My ...
- Mybatis动态SQL简单了解 Mybatis简介(四)
动态SQL概况 MyBatis 的强大特性之一便是它的动态 SQL 在Java开发中经常遇到条件判断,比如: if(x>0){ //执行一些逻辑........ } Mybatis应用中,S ...
- mybatis原理分析学习记录,mybatis动态sql学习记录
以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...
- mybatis 动态sql和参数
mybatis 动态sql 名词解析 OGNL表达式 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性, ...
- MyBatis动态SQL之一使用 if 标签和 choose标签
bootstrap react https://segmentfault.com/a/1190000010383464 xml 中 < 转义 to thi tha <if test=&qu ...
随机推荐
- 【cartographer_ros】四: 发布和订阅里程计odom信息
上一节介绍了激光雷达Scan传感数据的订阅和发布. 本节会介绍里程计Odom数据的发布和订阅.里程计在cartographer中主要用于前端位置预估和后端优化. 官方文档: http://wiki.r ...
- VGA设计(原理说明。Verilog代码实现,仿真结果)
各类显示屏的显示原理大部分是利用人眼的视觉暂留效应.比如之前的数码管显示就是设计每个周期内各个小段按顺序显示,来达到显示一个数字的效果. VGA同理,显示屏在显示时是一个像素一个像素地显示,在人眼看来 ...
- TFrecord写入与读取
Protocol buffers are Google's language-neutral, platform-neutral, extensible mechanism for serializi ...
- 使用Docker-compose搭建nginx-keepalived双机热备来实现高可用nginx集群
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_117 最近同学出去面试经常会被问到一个问题. 面试官:你说你们公司使用nginx反向代理tornado,部署了多少多少台机器,好像 ...
- Nginx 配置静态资源防盗链
# 什么是静态资源盗链: # 你服务器上的一张图片,127.0.0.1/images/a.png # 别人的html页面可以直接通过<img src="127.0.0.1/images ...
- 面向开发的内存调试神器,如何使用ASAN检测内存泄漏、堆栈溢出等问题
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 目录 介绍 如何使用 ASAN 检测内存泄漏 检测悬空指针访问 检测堆溢出 C++ 中的new/delete不匹配 检测栈 ...
- 技术分享|sysbench 压测工具用法浅析
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 介绍 新业务上线的时候通常需要对数据库性能进行压力测试,以确认是否满足需要,今天简单介绍下sysbench的用法: 1.s ...
- 前端监控系列2 |聊聊 JS 错误监控那些事儿
作者:彭莉,火山引擎 APM 研发工程师.2020年加入字节,负责前端监控 SDK 的开发维护.平台数据消费的探索和落地. 有必要针对 JS 错误做监控吗? 我们可以先假设不对 JS 错误做监控,试想 ...
- Excel 运算符(二):比较运算符
比较运算符用于对两个数据进行比较运算,其结果为 TRUE(真)或 FALSE(假). 运算符 含义 实例 结果 = 等于 =2=3 FALSE < 小于 =5<2 FALSE > 大 ...
- STC8H开发(十六): GPIO驱动XL2400无线模块
目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) ST ...