一. 在mybatis中, if test 判断不为空字串和null的时候,报了sql 语法错误

xml文件:

WHERE enable =1
<if test="keyword != null AND keyword != ''">
        AND ( mac_id = #{keyword} )
        OR ( user_id = #{keyword} )
 </if>

postman工具报错如下:
在这里插入图片描述

原因:
if 判断中, 出现字母大小写错误, 不符合mybatis 语法规范

在这里插入图片描述

二. 在mybatis中, if test 语法

1 判断不为null

WHERE 1=1
<if test="keyword != null ">
        AND  user_id = #{keyword} 
</if>

2 判断不为空字符串

WHERE 1=1
<if test="keyword != '' ">
        AND  user_id = #{keyword} 
</if>

3 判断不为null 且 不为空字符串

WHERE 1=1
<if test="keyword != null and keyword != ''">
        AND  user_id = #{keyword} 
</if>

三. Controller层 —> 对应xml 文件

我们在获取列表时, 通常会根据关键词进行精确或模糊查询,就会对关键词进行非空或者非null的判断.如下:

Controller层请求参数keyword 请求参数默认值 Dao层Xml 文件
@RequestParam(value = “keyword”, required = false) String keyword null if test="keyword != null "
@RequestParam(value = “keyword”, required = false, defaultValue = “”) String keyword 空字符串 if test="keyword != ‘’ "
/ 不清楚默认值 都可以if test=“keyword != null and keyword != ‘’”
参数 默认值 Dao层Xml 文件
从其他渠道的获取的数据或关键词 不清楚默认值 if test=“keyword != null and keyword != ‘’”
Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐