什么?面试被问到MyBatis,升职加薪绝招!看完一招搞懂动态SQL!

什么?面试被问到MyBatis,升职加薪绝招!看完一招搞懂动态SQL!

MyBatis——动态SQL

在这里插入图片描述

什么是动态SQL

简单的来说就是可以根据实时的业务需求动态的改变SQL语句。在程序还未编译的情况下SQL语句不能确定,而是在程序运行阶段并在执行过程中才能确定SQL语句,这就叫动态SQL语句。


为什么要使用动态SQL

在初级阶段我们的程序进行数据库操作时,书写的SQL语句都是确定的,就在程序运行前就已经写死了,我们不能根据实时业务对SQL进行实时更改,这样可能导致我们需要为业务编写的SQL语句繁多,举个例子:现在我需要根据10个不同的数据库表字段名进行查询,其中每个字段名都是可选的,如果不用动态SQL,使用静态SQL我们需要实现的SQL语句有多少?数学好的可以使用全排看看需要多少?【获取资料】

想想如果可以在SQL中来个if语句该有多好?那只需要编写一条SQL语句就可以满足需求了(美滋滋),所以动态SQL的重要性不言而喻,在如今的大数据时代,如果没有动态SQL,业务的开发周期可想而知有多长!


MyBatis的动态SQL

接下来就看官方文档吧!应该没有什么是博客加官方文档解决不了的。如果有那就再看几遍!
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FdCFHDjX-1626962244641)(https://jq.qq.com/?_wv=1027&k=jYRaGbBI)]](https://img-blog.csdnimg.cn/e03de534bbff4e0c9a01c217f769dd57.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0RlbGlsYWhfamF2YQ==,size_16,color_FFFFFF,t_70#pic_center)

动态SQL小结

  • if
    条件判断,是最常用的,也是最有效的。

  • where
    where 元素只会在子元素返回任何内容的情况下才插入 “WHERE” 子句。而且,若子句的开头为 “AND” 或 “OR”,where 元素也会将它们去除。

  • set
    set 元素会动态地在行首插入 SET 关键字,并会删掉额外的逗号(这些逗号是在使用条件语句给列赋值时引入的)。通过介绍得知,set元素只能用在修改操作

  • foreach
    这个也是比较重要的元素,重点在于理解collection属性!

  • choose、when、otherwise
    这个就是Java中的switch-case,分支选择。choose类似于switch代码块,when类似于一个一个条件,otherwise则为最后默认的条件。

  • trim
    这个元素千万别以为他是简单“去空格”(一开始我也是这样认为的),他的功能非常强大,但是却不常用,我们可以通过自定义 trim 元素来定制其他动态SQL元素的功能,比如whereset…等,也许就因为太强大了,平常业务中并不需要,所以使用的不多(这就是无敌太寂寞?)。

  • include、sql
    这两个是搭配来使用的。

    • sql:这个元素申请在<mapper>标签的根下,作用是用来定义公共的SQL代码片段,一般是表的字段名,字段名过多的话,用sql元素定义并搭配include元素使用减少代码量。【参考资料】
    • include:包含,含有的意思,在代码中我们使用这个元素可以让指定让使用了sql元素定义的代码片段插入到SQL语句中
  • bind
    元素允许你在 OGNL 表达式以外创建一个变量,并将其绑定到当前的上下文。一般我们常用于模糊查询,像模糊查询我们写SQL时如果直接使用占位符来传参是不行的,所以需要使用字符串拼接的方式来传参,但是有可能导致sql注入,所以bind元素无疑是一种较好的选择。
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XUUun4HQ-1626962016452)(https://img-blog.csdnimgW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L0RlbGlsYWhfamF2YQ==,size_16,color_FFFFFF,t_70#pic_center)]
    在这里插入图片描述

当然,每个动态SQL的元素只要我们合理搭配,可以节省我们对SQL语句的开发时间以及代码量,让数据库开发更加高效,我们也只有在更多的实际业务或项目中使用动态SQL进行开发才能真正的体会到其便利性,高效性,也能更深刻的理解它,加油!!!。

分类: [MyBatis]

最后,祝大家早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

可以的话请给我一个三连支持一下我哟???

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值