mybatis的where标签怎么使用(mybatis,where,开发技术)

时间:2024-04-25 22:51:11 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    mybatis%E7%9A%84where%E6%A0%87%E7%AD%BE%E6%80%8E%E4%B9%88%E4%BD%BF%E7%94%A8

我们经常在动态构造sql时,为防止注入或防止语句不当时会使用where 1=1

但在使用where标签可以简化这条语句

这条sql执行时,如果id这个参数为null,则这条语句的执行结果为

这个‘where’标签会知道如果它包含的标签中有返回值的话,它就会插入一个‘where’。此外,如果标签返回的内容是以AND 或OR开头的,则会把它去除掉。

为了能达到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标签怎么使用的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:html5的新增标签keygen怎么用下一篇:

16 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18