加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

mybatis常用标签和动态查询

发布时间:2020-12-14 06:36:24 所属栏目:Java 来源:网络整理
导读:这里是修真院后端小课堂,每篇分享文从 【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】 八个方面深度解析后端知识/技能,本篇分享的是: 【mybatis常用标签和动态查询 】 修真院java小课堂】课题名称

这里是修真院后端小课堂,每篇分享文从

【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】

八个方面深度解析后端知识/技能,本篇分享的是:

【mybatis常用标签和动态查询 】

修真院java小课堂】课题名称

开场语:

大家好,我是IT修真院郑州分院第13期的学员崔震,一枚正直纯洁善良的java程序员,今天给大家分享一下,修真院官网后端(职业)任务1,深度思考中的知识点——mybatis常用标签和动态查询

(1)背景介绍:

mybatis框架是一个持久层框架,是Apache下的顶级项目。mybatis可以让开发者的主要精力放在sql上,通过mybatis提供的映射方式,自由灵活的生成满足需要的sql语句。使用Mybati后只需要提供sql语句,其他的工作都交给了Mybatis去做,比如创建连接,Statement,JDBC相关的异常处理。这些重复性的工作都交给了Mybatis去做,我们只需要关注增删查改操作层面的东西,而别的那些我们之前重复性的工作都被Mybatis封装。进而使代码更简洁,更易解读,更易维护

(2)知识剖析:

标签

if元素是最常用的判断语句相当于java中的if语句,他常常与test属性联合使用,if? test 就相当于判定,若符合标签标签中的条件,则在SQL语句上添加内的条件下面代码实战我们会详细讲到

标签

where标签经常跟if标签搭配使用,where标签会判断if标签里的条件是否成立,如果有条件成立则会拼接执行该条件下的sql语句。where标签避免所有条件都为空的时候出现“select * from user where ”这种会出错的情况,当然我们也可以在where后面加入“1=1”简单的解决。

标签

set标签一般用在update语句中,set标签与where标签类似,当我们在update语句里碰到多个字段相关的问题,在这种情况下我们就会用到set标签,他也是判断if标签里的条件是否成立,然后拼接执行sql语句。

标签

相比于if标签二选一,choose标签就有了第三种选择,或者更多的选择,在映射器的动态语句中使用choose..when..otherwise..这三个元素就能满足不同的业务要求,Mybatis会根据参数的设置进行判断,来拼接组装sql语句,当when标签下无满足条件,则会执行otherwise标签里的语句。

标签

foreach元素是一个循环语句,他的作用是遍历集合,他能够很好的支持数组和List的集合。并对此提供遍历,foreach标签常用于in这样的语法里,进行批量处理

(3)常见问题:

if标签与choose标签的区别

(4)解决方案:

if是不管条件成不成立都会执行下一条if;而choose中,如果when中先执行判断的成立了,则不会再往后执行。

(5)编码实战:

(6)拓展思考:

mybatis 除了使用xml方式还有别的方式吗?

还可以吧xml改为Mapper接口

(7)参考文献:

http://how2j.cn/k/mybatis/mybatis-tutorial/1087.html

http://www.mybatis.org/mybatis-3/

Q1:提问人:为什么要使用动态查询 A1:回答人:因为你不能确定用户在搜索时会输入什么,想要搜索什么字段,所以我们就使用动态查询,判断用户输入的内容进行相应的查询。 Q2:提问人:sql语句后面为什么要加where1=1 A2:回答人:因为如果下一个条件判断不成立,进行查询时sql语句就会是 select*from student where,传入这样的sql语句就会出错,因为where后面没有跟一个判断条件,所以我们给where后面加入一个1=1恒成立的判断条件sql语句就不会出错 Q3:提问人:if标签与choose标签的区别

A3回答人:if是不管条件成不成立都会执行下一条if;而choose中,如果when中先执行判断的成立了,则不会再往后执行。

(9)鸣谢:

感谢张亚强师兄,此教程是在他们之前技术分享的基础上完善而成。

(10)结束语:

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

PPT链接?视频链接

更多内容,可以加入IT交流群565734203与大家一起讨论交流

这里是技能树·IT修真院:,初学者转行到互联网的聚集地

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读