如何解决错误的 CASE SQL 语句
我编写了一条 SQL 语句,该语句返回无效字符。我知道它与我的 where 中的 case 语句有关,所以任何人都可以告诉我错误。谢谢。
WHERE
<if test="gNumber != null">
dph.GNUMBER = #{gNumber}
</if>
<if test="licence != null">
dph.dlicenceNumber = #{licence}
</if>
AND dph.REASON = (CASE WHEN dph.REASON IS NOT NULL THEN par.CODE END)
解决方法
显而易见的假设是标记代码不正确。但是您可能有一个可以删除它的预处理器。
如果标记是正确的代码,那么在某些情况下,逻辑会是:
WHERE AND . . .
这是不正确的。一个典型的方法是:
WHERE 1 = 1 AND
<if test="gNumber != null">
dph.GNUMBER = #{gNumber} AND
</if>
<if test="licence != null">
dph.dlicenceNumber = #{licence} AND
</if>
dph.REASON = (CASE WHEN dph.REASON IS NOT NULL THEN par.CODE END)
CASE
表达式本身不会导致错误。但话又说回来,这也不是必需的,因为 NULL
值无论如何都会失败。所以这是等价的:
WHERE 1 = 1 AND
<if test="gNumber != null">
dph.GNUMBER = #{gNumber} AND
</if>
<if test="licence != null">
dph.dlicenceNumber = #{licence} AND
</if>
dph.REASON = par.CODE
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。