动态SQL概况

MyBatis 的强大特性之一便是它的动态 SQL
在Java开发中经常遇到条件判断,比如:
if(x>0){
//执行一些逻辑........
}
 
Mybatis应用中,SQL映射通常位于XML文件内,在执行前需要将XML中的映射转换为最终要执行的SQL
在转换中是否可以根据输入动态的处理SQL?这就是动态SQL,比如
<select id="findActiveBlogWithTitleLike"
resultType="Blog">
SELECT * FROM BLOG
WHERE state = ‘ACTIVE’
<if test="title != null">
AND title like #{title}
</if>
</select>
上面的<if test="title != null"> 就是动态SQL处理,将会根据实际传递的title的值,动态的决定SQL的内容,是否包含最后面的AND
Mybatis的动态SQL元素不多,但是简单高效,Mybatis的动态SQL元素类似JSTL
类型主要有三种:
  • 条件判断
  • 内容处理
  • 循环处理

对于每种不同的类型又有各自的格式和属性
 

条件处理

if是最基本的一种形式,语意为:如果xxx就xxx
通过最基本的if可以构造很复杂的条件测试语句,相当于
if(){
}
choose是特殊化的if,相当于
if(){
}else{
}
你可以添加多个if,比如
if(){
}if(){
}if(){
}else{
}
通常对于一个choose是可以拆分为多个if条件的,但是很显然,某些场景下,使用if else的形式比多个if 要更加简单清晰
if和choose里面when后的条件都是使用test进行设置的

内容处理

trim用于动态内容头尾的处理,可以添加前缀prefix或者添加后缀suffix
也可以移除匹配的指定的前缀prefixOverrides,或者移除匹配的指定的后缀suffixOverrides
简言之可以借助于trim对拼接内容的头尾进行处理
where相当于
<trim prefix="WHERE" prefixOverrides="AND |OR ">

表示在最前面添加where,如果最开始是AND 或者OR 将会进行删除

set相当于<trim prefix="SET" suffixOverrides=",">

表示在最前面添加set,如果最后面是一个逗号,   将他删除

循环遍历

foreach用于动态的循环拼接,相当于for循环动态拼接内容
for(int i =0;i<list.size;i++){
String s +=“...”;
}
对于foreach,需要指明需要遍历循环的参数名称,通过collection指定
需要指定循环变量,也就是在循环中使用哪个变量指代,相当于Object o = list.get(i);  使用item指定的就是这个o
还可以指定变量用于记录索引,通过这个索引变量可以获得迭代的次数索引,通过index
对于open, separator, close,就是在字符串拼接的开头,中间,结尾,添加的分割符信息。

总结

在实际项目应用中,总是有很多的查询条件或者关联语句,但是并不是每一次的查询都需要完整的语句,难道每种场景都重新写一个SQL吗?
显然是效率低下的,Mybatis的动态SQL就是解决这种问题的
动态SQL就是根据条件动态的处理SQL语句,进而达到不同场景不同SQL的作用,也就是写一次SQL,然后经过条件分支或者内容的处理,能够在多个场景进行使用
从上面的介绍也可以看得出来,动态SQL的本质在于根据条件,对SQL语句处理,可以理解为文本处理工作
他只是Mybatis一次执行时实际执行的SQL语句,不管是if还是choose 还是where还是trim,再或者是foreach,都是简单的对SQL进行拼接、处理、优化
对于程序员来说,最重要的就是条件的判断,也就是test后面的语句的书写,再就是确认各种条件判断后处理后的SQL语句不会出现什么问题就够了
但是还需要注意,尽管Mybatis有动态SQL功能,可以灵活的拼接SQL,但是也不要滥用,尽可能业务逻辑比较相似的,通过条件进行控制
试想,如果一整个表的所有逻辑全都是一个SQL,通过各种if choose拼接起来,可读性是一个很大的问题,所以也要合理
简单说几点就是:
  • 动态SQL本质就是SQL语句的文本处理工作,无他
  • 要注意条件语句的设置
  • 不要滥用动态SQL,该分开还是得分开
对于动态SQL根本仍旧是SQL的编写,所以需要具有良好的SQL语句编写能力,动态SQL只是可以让他更加灵活,并不能解决你SQL中的任何问题,或者性能问题
要始终记住,他只是处理需要执行的SQL
 

Mybatis动态SQL简单了解 Mybatis简介(四)的更多相关文章

  1. MyBatis 动态SQL(十二)

    动态条件查询 以下是我们数据库表 tb_user 的记录: 假设现在有一个需求,就是根据输入的用户年龄和性别,查询用户的记录信息.你可能会说,这太简单了,脑袋里立马蹦出如下的 SQL 语句: SELE ...

  2. mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句

    mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...

  3. 9.mybatis动态SQL标签的用法

    mybatis动态SQL标签的用法   动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...

  4. 自己动手实现mybatis动态sql

    发现要坚持写博客真的是一件很困难的事情,各种原因都会导致顾不上博客.本来打算写自己动手实现orm,看看时间,还是先实现一个动态sql,下次有时间再补上orm完整的实现吧. 用过mybatis的人,估计 ...

  5. mybatis原理分析学习记录,mybatis动态sql学习记录

    以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...

  6. mybatis 动态sql和参数

    mybatis 动态sql 名词解析 OGNL表达式 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性, ...

  7. MyBatis动态sql之${}和#{}区别

    前言 ​ 接触mybatis也是在今年步入社会之后,想想也半年多了,缺没时间去系统的学习,只知道大概,也是惭愧. ​ 不知道有多少刚毕业的同学和我一样,到现在还没仔仔细细去了解你每天都会见到使用到的框 ...

  8. Mybatis 动态Sql语句《常用》

    MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉 ...

  9. mybatis 动态sql语句(3)

    mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类: 1. if 语句 (简单的条件判断) 2. ...

随机推荐

  1. Pycharm安装+python安装+环境配置

    Pycharm 工具: 1.安装jdk(64位):jdk-8u65-windows-x64.exe 路径:C:\Program Files\Java(默认路径) 2.配置环境 步骤一: 系统变量→新建 ...

  2. ubuntu 18.04 安装mysql 8.0

    1.下载配置(不然直接装的是mysql5.7): wget https://repo.mysql.com//mysql-apt-config_0.8.10-1_all.deb 2.更新配置: sudo ...

  3. 程序执行流程/布尔类型与布尔:运算猜数字游戏;库的使用:turtle

    myPrice = 6 while True: guess = int(input()) if guess > myPrice: print('>') elif guess < my ...

  4. codeforces 13 b

    给你三根线段判段是否组成了A 条件,两条线段交于端点并且夹角不大于90,第三条线段端点在两条线段上并且划分的大小满足 大:小<4:1 注释很全.(主要是我记不清楚了,,好像过了一个多星期了) # ...

  5. linux操作命令之搜索命令

    1.文件搜索命令:locate 文件名 在后台数据库中按照文件名搜索,搜素速度更快 /var/lib/mlocate:#locate命令所搜索的后台数据库 updatedb:更新数据库 updated ...

  6. R语言之Apriori算法

    ---恢复内容开始--- 1.概念 关联分析:用于发现隐藏在大型数据集中的有意义的联系 项集:0或多个项的集合.例如:{啤酒,尿布,牛奶,花生} 是一个4-项集,意义想象成爸爸去超市买啤酒和花生,给儿 ...

  7. C语言面试题分类->指针

    有关指针的经典面试题 C语言为何如此长寿并实用?C++为什么有那么多精彩?指针可以说是C/C++中的灵魂所在,虽然早期中pascal也有指针,但是和C/C++比起来不是一个级别的.今天为大家深入浅出的 ...

  8. NeuChar 平台使用及开发教程(五):使用 NeuChar 的关键字回复服务

    在上一篇<NeuChar 平台使用及开发教程(四):使用 NeuChar 的素材服务>中,我们已经完成了素材的添加,下面,让我们来设置一个关键字回复,并同步到应设置好Neural Endi ...

  9. .net core2.1 使用 dynamic 类型报错

    在net core2.0项目中使用 dynamic 无法编译通过 异常信息:缺少编译器要求的成员"Microsoft.CSharp.RuntimeBinder.CSharpArgumentI ...

  10. 【RL-TCPnet网络教程】第35章 FTP文件传输协议基础知识

    第35章      FTP文件传输协议基础知识 本章节为大家讲解FTP(File Transfer Protocol,文件传输协议)的基础知识,方便后面章节的实战操作. (本章的知识点主要整理自网络) ...