mybatis的sql中,如果一个条件column=#{column},column的值为null时,会不会匹配出column is null 的记录

在 MyBatis 的 SQL 映射文件中,当你使用 column = #{column}这种写法,并且传入的参数 column的值为 null时,​不会 匹配出 column IS NULL的记录。

原因如下:

  1. SQL 语义:​

    • column = NULL在 SQL 中是一个无效的比较。在 SQL 标准中,任何值与 NULL进行比较(使用 =<><>等)的结果都是 UNKNOWN(不是 TRUE)。因此,column = NULL这个条件永远不会为 TRUE,也就不会返回任何行。

    • 要检查一个列是否为 NULL,必须使用专门的 IS NULL操作符。

  2. MyBatis 的参数替换:​

    • MyBatis 在执行 SQL 语句之前,会使用 JDBC 的 PreparedStatement进行参数替换。

    • 当参数 #{column}的值为 null时,MyBatis 会将其替换为 JDBC 的 NULL值(即 setNull(...))。

    • 最终发送到数据库的 SQL 语句看起来像这样:... WHERE column = NULL ...

    • 正如第 1 点所述,column = NULL在 SQL 中是不起作用的。

结果:​

  • column参数为 null时,column = #{column}这个条件相当于 column = NULL

  • column = NULL在 SQL 中总是求值为 UNKNOWN

  • 因此,​该条件不会匹配任何行,包括那些 column IS NULL的行。​

如何正确匹配 NULL?​

如果你希望在参数为 null时匹配 column IS NULL的记录,你需要使用 MyBatis 的动态 SQL 功能(通常是 <if>标签)来改变 SQL 语句的结构:

复制代码
<select id="findByColumn" resultType="YourResultType">
  SELECT * FROM your_table
  <where>
    <if test="column != null">
      column = #{column}
    </if>
    <if test="column == null">
      column IS NULL
    </if>
  </where>
</select>

  • <where>标签会智能地处理 WHERE关键字和 AND/OR的连接问题。

  • 第一个 <if test="column != null">:当参数 column的值不为 null时,生成 column = #{column}条件。

  • 第二个 <if test="column == null">:当参数 column的值为 null时,生成 column IS NULL条件。

这样,无论参数 column是具体的值还是 null,你都能正确地查询到期望的记录:

  • 传入非 null值:匹配该值的记录。

  • 传入 null:匹配 column IS NULL的记录。

​在 MyBatis 中,直接使用 column = #{param}paramnull时,不会匹配 column IS NULL的记录。必须使用动态 SQL(如 <if>)根据参数值动态生成 = valueIS NULL条件才能实现预期的查询行为。

相关推荐
技术砖家--Felix6 小时前
Spring Boot数据访问篇:整合MyBatis操作数据库
数据库·spring boot·mybatis
我想进大厂8 小时前
Mybatis中# 和 $的区别
java·sql·tomcat
码顺8 小时前
记录一次Oracle日志listener.log文件大小超过4G后出现Tomcat服务启动一直报错的原因【ORACLE】
数据库·oracle·tomcat
乐维_lwops8 小时前
zabbix进阶教程:Jmx用户认证监控tomcat
java·tomcat·zabbix
my一阁8 小时前
tomcat web实测
java·前端·nginx·tomcat·负载均衡
一只小透明啊啊啊啊8 小时前
SQL 查询语句的子句的执行顺序
数据库·sql
寒月霜华9 小时前
JavaWeb后端-JDBC、MyBatis
spring boot·junit·mybatis
啊吧怪不啊吧9 小时前
SQL之表的查改(上)
服务器·数据库·sql
yangchanghua11118 小时前
[记录]一个30秒的sql,我是怎么把它改到0.5秒的
数据库·sql·性能优化