9、mybatis中动态sql的使用

对于初学者,如何进行mybatis的学习呢?我总结了几点,会慢慢的更新出来。首先大家需要了解mybatis是什么、用mybatis来做什么、为什么要用mybatis、有什么优缺点;当知道了为什么的时候就开始了解如何用的问题,如何使用mybatis、有几种使用方式、各种方式的优缺点,在这个阶段也会学习mybatis涉及到的一些标签的用法;当知道了基础用法之后,就开始接触一些高级的用法,例如动态sql的使用、mybatis的缓存使用等;至此,在实战项目中使用mybatis进行开发已经没有问题了。

接下来就开始深入的研究一下mybatis这个持久层的框架,在纯技术的方面进行研究,提高自己的能力。首先,大家需要了解一下mybatis的整体技术架构和工作原理;接下来,就开始了解一下mybatis各大核心组件的具体功能及其工作原理。至此,算是对mybatis的原理简单的了解一下了,由于博主的能力有限,因此对于mybatis的框架技术研究也就到这里算结束了。

最后会了解一些其他的东西,例如:mybatis的逆向工程使用、如何开发一个mybatis插件,在这里会介绍一下mybatis的分页实现等。

至此,mybatis也算是入门了,出去就可以和别人说,你稍微了解mybatis框架,对其也多少有一点自己的理解和看法了。

目录

1、动态sql 如何理解?

1、1 什么是动态sql

1、2 OGNL 表达式        

2、动态sql 如何使用?

2、1 if 、where、set 标签

2、2 choose (when、otherwise)标签

2、3 trim 标签

2、4 foreach 标签


之前的 文章中 已经描述了mybatis进行增、删、改、查基本操作的处理方法,还有如何使用输入映射和输出映射。mybatis 为了提高易用性和灵活性,还提供了动态sql的功能。

1、动态sql 如何理解?

1、1 什么是动态sql

简单一句话,mybatis 可以根据特定的条件实现映射文件中 sql语句的动态拼接,这就是动态sql。

想一种场景,将User 传入到sql映射文件,根据user_name 或者 age 进行数据的查询,如果user_name 或者 age 为空时,则不需要添加这个条件,如何实现呢?带着这个问题继续往下看。

1、2 OGNL 表达式        

mybatis 中动态sql的实现使用的是一系列的标签和属性,这些是基于OGNL 表达式。那么什么是OGNL 表达式呢?

我没有研究过OGNL表达式,这里对此就不做具体描述了,看一下百度百科的介绍:OGNL是Object-Graph Navigation Language的缩写,它是一种功能强大的表达式语言,通过它简单一致的表达式语法,可以存取对象的任意属性,调用对象的方法,遍历整个对象的结构图,实现字段类型转化等功能。它使用相同的表达式去存取对象的属性。这样可以更好的取得数据。

OGNL 通过链式风格访问对象及其属性。

2、动态sql 如何使用?

mybatis 中动态sql的实现依赖的是一系列的标签,包括:if、choose、when、otherwise、trim、where、set、foreach 等,具体介绍和使用说明如下。

2、1 if 、where、set 标签

if 标签,同java 中的if,进行条件判断,在sql 映射文件中的基本用法如下:

<select id="getUsers" resultType="map">select * from user where<if test="id != null">id = #{id}</if><!-- ognl会自动将数字和字符串进行转换 --><if test="age == 0">and age = #{age}</if>
</select>

例如:上边这个写法,如果id == null,就会到sql 错误,针对于这种情况,有两种处理方式: 

第一种就是流行最广泛的,直接使用万能语句“where 1=1”;

第二种是使用where标签,具体用法如下:

<!-- 此时 and 要写在前边 -->
<where><if test="id != null">and id = #{id}</if><if test="age == 0">and age = #{age}</if>
</where>

 第三种是使用trim 自定义标签规则实现,具体用法在 2、3 展示。

set 标签一般用在进行数据修改sql 的拼接上,具体使用如下:

<update id="updateStudent">update student<!-- 会自动添加set ,并去掉无用的 逗号,类似于 where 标签 --><set><if test="name != null">name = #{name}, </if><if test="age != null">age = #{age}, </if><if test="sex != null">sex = #{sex}, </if></set>where id = #{id}
</update>

2、2 choose (when、otherwise)标签

选择标签,类似于java中的 switch,具体使用如下:

<select id="selectUsers" resultType="map"><where><choose><!-- 注意:每次只会进入一个分支 --><when test="id != null">id=#{id}</when><when test="name != null">name = #{name}</when><otherwise>age = #{age}</otherwise></choose></where>
</select>

2、3 trim 标签

trim 标签可以用来自定义拼接的规则(或者是指定sql 语句拼接时截取的规则),trim 中返回的内容是整个字符串拼接后的结果使用,接下俩使用trim 标签继续实现 2、1 中的需求,具体如下:

<!-- prefix: 给拼接后的字符串添加一个前缀 where -->
<!-- prefixOverrides:去掉整个字符串前面为and的字符串-->
<!-- suffix:给拼接后的字符串添加一个后缀 and-->
<!-- suffixOverrides:去掉整个字符串后面为 and的字符串--><select id="selectUsers" resultType="map"><trim prefix="where" suffix="and" suffixOverrides="and"><if test="id != null">id = #{id}</if><if test="age == 0">age = #{age}</if></trim>
</select>

因为 trim 是自定义拼接的规则,所以,使用trim 也可以实现set 标签的功能,大家可以自己尝试写一下,发到评论区,大家一起看一下,在这里就不写了。 

2、4 foreach 标签

循环拼接时用到的标签,一般用于批量数据添加,对传进来的 list 进行循环拼接查询语句,具体使用方式如下:

<!--  批量添加记录的写法使用 foreach 进行批量添加语句的拼接,其中collection 是接受的数据类型,item 是迭代的每一个元素separator 是连接符
-->
<insert id="insertUserList" useGeneratedKeys="true" keyProperty="id">insert into oa_user (id, loginName, name) values<foreach collection="list" item="user" separator=",">(#{user.id}, #{user.loginName}, #{user.name})</foreach>
</insert>

好了,如果同学从 第一篇 一直看到这个地方,对于mybatis 的使用应该是有一定的了解了,在实际开发中应该没有问题了。之后,编写的文章中,更多的是对于一些原理性的底层性的知识介绍,有兴趣的同学可以继续。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321412.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软件质量保证划重点期末复习总结

软件质量保证复习总结大纲及问题 Module1 《软件工程实践》 1、软件工程实践通过解决问题的根源来指导软件开发。 2、软件工程实践之间相辅相成。 3、过程指导一个团队在什么时候做什么以及如何做。 4、软件工程过程为实现软件工程实践提供了上下文和支持。 Module2 《软件…

P4721-[模板]分治FFT【NTT,分治】

正题 题目链接:https://www.luogu.com.cn/problem/P4721 题目大意 给出序列ggg&#xff0c;然后f01f_01f0​1 fi∑j1ifi−jgjf_{i}\sum_{j1}^if_{i-j}g_jfi​j1∑i​fi−j​gj​ 求序列fff 解题思路 使用分治后用NTTNTTNTT计算前区间对后区间的贡献即可。 时间复杂度O(nlo…

Microsoft Build 2018 直播来啦!

一年一度的Microsoft Build大会又来啦&#xff01;Microsoft Build是微软面向全球开发者、合作伙伴以及消费者介绍其重要产品在未来一年内发展方向的技术盛会。而今年的Microsoft Build 2018大会是微软巨大蜕变、最彻底组织变革后的第一次前沿技术大会。更多了解&#xff0c;请…

【动态规划】矩阵链相乘 (ssl 1596)/能量项链 (ssl 2006)

矩阵链相乘{\color{Cyan} 矩阵链相乘 }矩阵链相乘 Description Input n表示矩阵的个数(<100) n1个数,表示矩阵(<100) Output 最小的乘法次数 Sample Input 5 5 10 4 6 10 2 Sample Output 348 题目大意&#xff1a; 有n个矩阵&#xff0c;输入n1个数&#x…

10、mybatis中缓存的使用

对于初学者&#xff0c;如何进行mybatis的学习呢&#xff1f;我总结了几点&#xff0c;会慢慢的更新出来。首先大家需要了解mybatis是什么、用mybatis来做什么、为什么要用mybatis、有什么优缺点&#xff1b;当知道了为什么的时候就开始了解如何用的问题&#xff0c;如何使用my…

C#编译器优化那点事

使用C#编写程序&#xff0c;给最终用户的程序&#xff0c;是需要使用release配置的&#xff0c;而release配置和debug配置&#xff0c;有一个关键区别&#xff0c;就是release的编译器优化默认是启用的。优化代码开关即optimize开关&#xff0c;和debug开关一起&#xff0c;有以…

P3195-[HNOI2008]玩具装箱【斜率优化dp】

正题 题目链接:https://www.luogu.com.cn/problem/P3195 题目大意 nnn个物品&#xff0c;分成若干段&#xff0c;每一段的长度为j−i∑ilrCkj-i\sum_{il}^rC_kj−i∑ilr​Ck​&#xff0c;打包价格为(长度−L)2(长度-L)^2(长度−L)2 求最小价格和。 解题思路 si∑j1iCjs_i\su…

【动态规划】书的复制 (ssl 1203)

书的复制书的复制书的复制 Description 现在要把m本有顺序的书分给k个人复制&#xff08;抄写&#xff09;&#xff0c;每个人的抄写速度都一样&#xff0c;一本书不允许分给两个或两个以上的人抄写&#xff0c;分给每个人的书&#xff0c;必须是连续的&#xff0c;比如不能把…

P1975-[国家集训队]排队【树状数组套线段树】

正题 题目链接:https://www.luogu.com.cn/problem/P1975 题目大意 一个nnn个数字的序列&#xff0c;每次交换两个数&#xff0c;求逆序对。 解题思路 显然交换lll和rrr的话对[1..l−1][1..l-1][1..l−1]和[r1,n][r1,n][r1,n]是不会有影响的&#xff0c;所以我们只需要考虑ll…

【动态规划】分组背包 (ssl 2291)

分组背包分组背包分组背包 Description 有N件物品和一个容量为V的背包。第i件物品的费用是c[i]&#xff0c;价值是w[i]。这些物品被划分为若干组&#xff0c;每组中的物品互相冲突&#xff0c;最多选一件。求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量&#…

如何在Visual Studio 2017中使用C# 7+语法

前言之前不知看过哪位前辈的博文有点印象C# 7控制台开始支持执行异步方法&#xff0c;然后闲来无事&#xff0c;搞着&#xff0c;搞着没搞出来&#xff0c;然后就写了这篇博文&#xff0c;不喜勿喷&#xff0c;或许对您有帮助。在Visual Studio 2017配置支持C# 7语法心想都VS20…

11、mybatis的功能架构分析

1、Mybatis功能架构 1&#xff09;API接口层&#xff1a;提供给外部使用的接口API&#xff0c;开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。 2&#xff09;数据处理层&#xff1a;负责具体的SQL查找、SQL解析、SQL执…

我的ACM之路-写于南宁站后

先说说我的ACM之路吧。自大一下学期开学开始&#xff0c;受到OI大佬舍友的影响&#xff0c;遂入坑。开始啃白书和紫书&#xff0c;然而发现好难啊。意识到大概是自己算法和数据结构知识欠缺的太厉害了&#xff0c;于是去网上买了本数据结构的教材&#xff08;隐约记得是清华大学…

P1903-[国家集训队]数颜色/维护队列【带修莫队】

正题 题目链接:https://www.luogu.com.cn/problem/P1903 题目大意 要求支持两个操作 QLR:Q\ \ L\ \ R:Q L R:询问L,RL,RL,R之间有多少个不同的数RPCol:R\ \ P\ \ Col:R P Col:将PPP修改为ColColCol 解题思路 莫队中多加一个时间维度ttt表示前面有多少个修改操作&#xf…

【动态规划】方格取数 (ssl 1010)

方格取数方格取数方格取数 Description 设有N*N的方格图(N<10,我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0。如下图所示&#xff08;见样例&#xff09;&#xff1a; 某人从图的左上角的A 点出发&#xff0c;可以向下行走&#xff0c;也可以向右走&#…

ASP.NET Core 使用UrlFirewall对请求进行过滤

一. 前言UrlFirewall 是一个开源、轻便的对http请求进行过滤的中间件&#xff0c;可使用在webapi或者网关&#xff08;比如Ocelot&#xff09;,由我本人编写&#xff0c;并且开源在github&#xff1a;https://github.com/stulzq/UrlFirewall 欢迎star.二.UrlFirewall 介绍UrlFi…

1、设计模式和原则总述

目录 一、什么是设计模式&#xff1f;有什么用&#xff1f; 二、设计模式 三、设计原则 一、什么是设计模式&#xff1f;有什么用&#xff1f; 设计模式是一套代码设计的经验总结&#xff0c;使用设计模式可以提高代码的重用性、可靠性&#xff0c;提交代码内聚&#xff0c;降…

P3600-随机数生成器【dp,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/P3600 题目大意 nnn个数的序列&#xff0c;每个数是[1..x][1..x][1..x]中的一个&#xff0c;有qqq个区间[l..r][l..r][l..r]&#xff0c;求所有区间最小值的最大值的期望。 解题思路 首先如果一个区间包含别的区间&#xff0…

Visual Studio 15.7预览版4改进Git、C++支持

对于即将到来的Visual Studio 2017 15.7&#xff0c;微软已经发布了多个新的预览版本。这些版本的变更很有限&#xff0c;似乎离正式发布不远了。通常&#xff0c;变更的涉及面很广——因此&#xff0c;不管是用什么语言&#xff0c;开发人员都可以看到一些好处。第一次&#x…

【动态规划】农田个数 (ssl 1633)

农田个数农田个数农田个数 Description 你的老家在河北农村。过年时&#xff0c;你回老家去拜年。你家有一片NM农田&#xff0c;将其看成一个NM的方格矩阵&#xff0c;有些方格是一片水域。你的农村伯伯听说你是学计算机的&#xff0c;给你出了一道题&#xff1a; 他问你…