Spring Mybatis 动态语句 总结

news/2024/9/22 6:48:08/

1.简介

Mybatis 提供动态语句的功能来增强多条件变动的查询语句。

2.代码

if和where搭配使用:

<select id="query" resultType="a">select * from t_a<where><!--  where内没有条件满足,不转成where,有条件满足转成where。自动去掉多余的and和or --><if test="name != null">a_name = #{name}</if><if test="price != null and price &gt; 100"><!--  &gt;是 >  &lt;是 < -->and a_prirce = #{price}</if></where>
</select>

set标签用于去掉多余逗号,和自动添加set关键字:

<!--    set标签用于去掉多余逗号,和自动添加set关键字-->
<update id="update">update t_a<set><if test="aName != null">a_name = #{aName},</if><if test="aPrice != null">a_price = #{aPrice}</if>where a_id = #{aId}</set>
</update>

trim可以自定义添加关键字,去掉指定字符:

<select id="queryTrim" resultType="a">select * from t_a<!--  自动添加where,去掉多余前缀的and和or --><trim prefix="where" prefixOverrides="and|or" sufixOverrides="and|or"><if test="name != null">a_name = #{name}</if><if test="price != null and price &gt; 100"><!--  &gt;是 >  &lt;是 < -->and a_prirce = #{price}</if></trim>
</select><select id="queryTrim" resultType="a">select * from t_a<!--  自动添加where,去掉多余后缀的and和or --><trim prefix="where" sufixOverrides="and|or"><if test="name != null">a_name = #{name} and</if><if test="price != null and price &gt; 100"><!--  &gt;是 >  &lt;是 < -->a_prirce = #{price}</if></trim>
</select>

choose搭配when使用实现类似switch的功能:

<select id="queryChoose" resultType="a">select * from t_empwhere<!-- 如果name !=null 则用name查询,如果name == null 则用price查询,如果都不满足,则走otherwise分支 --><choose><when test="name != null">a_name = #{name} and</when><when test="salary != null">a_price = #{salary}</when><otherwise>1=1</otherwise></choose>
</select>

foreach实现批量查询:

<select id="queryBatch" resultType="a">select * from t_awhere a_id in<!-- 实现(id1,id2,id3...idn)--> <foreach collection="ids" open="(" separator="," close=")" item="id">#{id}</foreach>     
</select>

sql标签组成片段,被其他地方引用:
<sql id="mySql">select * from t_a
</sql>
<select id="query" resultType="a"><include refid="mySql"/>
</select>

http://www.ppmy.cn/news/1528718.html

相关文章

【数据结构与算法 | 灵神题单 | 自底向上DFS篇】力扣965, 2331, 100, 1379

1. 力扣965&#xff1a;单值二叉树 1.1 题目&#xff1a; 如果二叉树每个节点都具有相同的值&#xff0c;那么该二叉树就是单值二叉树。 只有给定的树是单值二叉树时&#xff0c;才返回 true&#xff1b;否则返回 false。 示例 1&#xff1a; 输入&#xff1a;[1,1,1,1,1,n…

计算机毕业设计 健身房管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

好用的工具网址

代码类&#xff1a; 1,json解析&#xff1a;JSON在线解析及格式化验证 - JSON.cn 2.传参转化编码 在线url网址编码、解码器-BeJSON.com 日常&#xff1a; 1.莆田医院查询&#xff1a;滚蛋吧&#xff01;莆田系

C++类和对象(4)

1. 再探构造函数 之前我们实现构造函数时&#xff0c;初始化成员变量主要在构造函数体内赋值&#xff0c;构造函数初始化还有⼀种方 式&#xff0c;就是初始化列表&#xff0c;初始化列表的使用方式是以⼀个冒号开始&#xff0c;接着是⼀个以逗号分隔的数据成 员列表&#xf…

macOS 中搭建 Flutter 开发环境

如果你的 Mac 是 Apple silicon 处理器&#xff0c;那么有些 Flutter 组件就需要通过 Rosetta 2 来转换适配&#xff08;详情&#xff09;。要在 Apple silicon 处理器上运行所有 Flutter 组件&#xff0c;请运行以下指令来安装 Rosetta 2。 sudo softwareupdate --install-ro…

微信小程序----日期时间选择器(自定义时间精确到分秒)

目录 页面效果 代码实现 注意事项 页面效果 代码实现 js Component({/*** 组件的属性列表*/properties: {pickerShow: {type: Boolean,},config: Object,},/*** 组件的初始数据*/data: {pickerReady: false,// pickerShow:true// limitStartTime: new Date().getTime()-…

Go进阶概览 -【7.1 反射机制与动态编程】

7.1 反射机制与动态编程 反射是Go语言的一项强大特性&#xff0c;使得程序可以在运行时检查和修改自身的结构和行为。 反射机制的使用在一些动态编程场景中非常重要&#xff0c;但同时也带来了一定的性能开销。 本节我们将深入解析Go的反射机制&#xff0c;探讨其在动态编程…

大数据-141 - ClickHouse 集群 副本和分片 Zk 的配置 Replicated MergeTree原理详解

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…