Mybatis的where标签如何使用


这篇文章主要讲解了“Mybatis的where标签如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mybatis的where标签如何使用”吧!在不使用Mybati免费云主机域名s的where标签时,我们通常是根据查询条件进行手动拼接,也就是用到了上面提到的where 1=1的方式,示例如下:这种方式主要就是为了避免语句拼接错误,出现类似如下的错误SQL:当添加上1=1时,SQL语句便是正确的了:这个我们之前已经提到过,多少对MySQL数据库的有一定的压力。因为1=1条件的优化过滤是需要MySQL做的。如果能够将这部分放到应用程序来做,就减少了MySQL的压力。毕竟,应用程序是可以轻易地横向扩展的。为了能达到MySQL性能的调优,我们可以基于Mybatis的where标签来进行实现。where标签是顶层的遍历标签,需要配合if标签使用,单独使用无意义。通常有下面两种实现形式。方式一:方式二:仔细观察会发现,这两种方式的区别在于第一if条件中的SQL语句是否有and这里就涉及到where标签的两个特性:第一,只有if标签有内容的情况下才会插入where子句;第二,若子句的开通为 “AND” 或 “OR”,where标签会将它替换去除;所以说,上面的两种写法都是可以了,Mybatis的where标签会替我们做一些事情。但需要注意的是:where标签只会智能的去除(忽略)首个满足条件语句的前缀。所以建议在使用where标签时,每个语句都最好写上 and 前缀或者 or 前缀,否则像以下写法就会出现问题:生成的SQL语句如下:很显然,语法是错误的。因此,在使用where标签时,建议将所有条件都添加上and或or;上面使用where标签可以达到拼接条件语句时,自动去掉首个条件的and或or,那么如果是其他自定义的关键字是否也能去掉呢?此时,where标签就无能为力了,该trim标签上场了,它也可以实现where标签的功能。将上面基于where标签的写改写为trim标签,发现执行效果完全一样。而且trim标签具有了更加灵活的自定义性。另外,在使用where语句或其他语句时一定要注意一个地方,那就是:注释的使用。先来看例子:上述SQL语句中添加了/**/的注释,生成的SQL语句为:执行时,直接报错。还有一个示例:生成的SQL语句为:同样会导致报错。这是因为我们使用 XML 方式配置 SQL 时,如果在 where 标签之后添加了注释,那么当有子元素满足条件时,除了 注释会被 where 忽略解析以外,其它注释例如 // 或 /**/ 或 — 等都会被 where 当成首个子句元素处理,导致后续真正的首个 AND 子句元素或 OR 子句元素没能被成功替换掉前缀,从而引起语法错误。同时,个人在实践中也经常发现因为在XML中使用注释不当导致SQL语法错误或执行出错误的结果。强烈建议,非必要,不要在XML中注释掉SQL,可以通过版本管理工具来追溯历史记录和修改。感谢各位的阅读,以上就是“Mybatis的where标签如何使用”的内容了,经过本文的学习后,相信大家对Mybatis的where标签如何使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是百云主机,小编将为大家推送更多相关知识点的文章,欢迎关注!

相关推荐: 怎么实现SSM分页

今天小编给大家分享一下怎么实现SSM分页的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.页面用bootstrapTable实现(配置查询的参数…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 05/07 12:23
下一篇 05/07 12:23

相关推荐