Mybatis学习笔记之动态SQL揭秘

网友投稿 239 2023-01-19


Mybatis学习笔记之动态SQL揭秘

前言

MyBatis 的强大特性之一便是它的动态 SQL。所以今天在这里为大家介绍一下Mybatis的一个强大功能-动态SQL

动态SQL是Mybatis的一个强大的特性,在使用JDBC操作数据时,如果查询条件特别多,将条件串联成SQL字符串是一件非常痛苦的事情,通常的解决方法使写很多的if-else条件语句去判断和拼接,并确保不能忘了空格或在字段的最后省略逗号。Mybatis使用一种强大的动态SQL语言来改善这种情况

动态SQL基于OGNL的表达式,可使我们能方便地在SQL语句中实现某些逻辑,那么有哪些元素来支持这种功能呢?这就是下面我要说的了

if:利用if实现简单的条件选择

choose(when,otherwise):相当于java中的switch语句,通常与when和otherwise搭配

where:简化SQL语句中where的条件判断

set:解决动态更新语句

trim:可以灵活地去除多余的关键字

foreach:迭代一个集合,通常用于in条件

上面所说的这些元素,都是用于mapper.xml文件中的,并且它还是一个标签,双标签。其实用法和咱们普通的编写java用法差不多,接下来就来一一讲解一下单个的元素都好说,来说说组合标签

使用if+where实现多条件查询

select * from user

and userName like CONCAT('%',#{userName},'%')

上述代码就是一个最简单的if+where的SQL映射语句,where元素标签会自动识别其标签内是否有返回值,若有,就插入一个where关键字,此外,若该标签返回的内容是以and或者or开头的,where元素会将其自动剔除,if元素标签里主要的属性就是test属性,test后面跟的是一个表达式,返回true或者false,以此来进行判断。

使用if+trim实现对条件查询

select * from user

and userName like CONCAT('%',#{userName},'%')

从上述代码中可以看出trim和where元素标签的用法差不多,就trim标签中多了几个元素,那多了啥元素呢?

prefiXkFmuMMJEXx:前缀,作用是在trim包含的内容上加上前缀。

suffix:后缀,作用是在trim包含的内容上加上后缀。

prefixOverride:对于trim包含内容的首部进行指定内容(如此出的“and|or“)的忽略。

suffixOverride:对于trim包含内容的首尾部进行指定内容的忽略。

接下来再来看看使用动态SQL来实现更新操作

使用if+set实现更新操作

update app_info

logoPicPath=#{logoPicPath},

logoLocPath=#{logoLocPath},

modifyBy=#{modifyBy},

modifyDate=#{modifyDate},

where id=#{id}

上述代码就是一个最简单的if+set的动态SQL,从上面的代码中能看出其所做的更新操作是动态的,意思就是说你这个值为不为空,不为空就给你更新,要是为空就不管它,emmmm,看样子它的设计还是很人性化的。

上面的操作也是可以用trim来实现的

if+trim实现更新操作

update app_info

logoPicPath=#{logoPicPath},

logoLocPath=#{logoLocPath},

modifyBy=#{modifyBy},

modifyDate=#{modifyDatXkFmuMMJEXe},

之前已经介绍过trim的用法了,在这里就不再赘述了,认真的童鞋应该都明白了。

接下来就是使用foreach完成复杂查询,先说说Mybatis入参为数组的foreach迭代

先带大家了解一下foreach的基本用法和属性,foreach主要用于在构建in条件中,它可以在SQL语句中迭代一个集合。它的属性主要有:item、index、collection、separator、close、open,下面我们来看代码

select * from user_info where userRole in

#{roleIds}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:科研研发管理平台网站官网(科研发表平台)
下一篇:关于post测试类的信息
相关文章

 发表评论

暂时没有评论,来抢沙发吧~