Java查询时间段(startTime
652
2022-08-21
mybatis if test 不为空字符串且不为null的问题
目录iftest不为空字符串且不为null在mybatis中iftest 在mybatis中,iftest语法Controller层—>对应xml文件mybatis把0当做空字符串我们在可能入参为0的地方多加一个判断
if test不为空字符串且不为null
在mybatis中if test
判断不为空字串和null的时候,报了sql 语法错误
xml文件:
WHERE enable =1
AND ( mac_id = #{keyword} )
OR ( user_id = #{keyword} )
postman工具报错如下:
原因:
if 判断中, 出现字母大小写错误, 不符合mybatis 语法规范
在mybatis中, if test 语法
1 判断不为null
WHERE 1=1
AND user_id = #{keyword}
2kqZacA 判断不为空字符串
WHERE 1=1
AND user_id = #{keyword}
3 判断不为null 且 不为空字符串
WHERE 1=1
AND user_id = #{keyword}
Controller层 —> 对应xml 文件
我们在获取列表时,通常会根据关键词进行精确或模糊查询,就会对关键词进行非空或者非null的判断。如下:
Controller层请求参数keyword请求参数默认值Dao层Xml 文件@RequestParam(value = “keyword”, required = false) String keywordnullif 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 != ‘’”
mybatis把0当做空字符串
在开发中,一般在sqlmap中都会判断参数是否为null,以及是否为空字符串
当参数为Int类型 0时,myBatis自动把0定义为空字符串“”
我们在可能入参为0的地方多加一个判断
,a.AUTHORIZE_AMOUNT = #{authorizeAmount,jdbcType=VARCHAR}
这是一个比较容易粗心的地方,出问题也不容易排查,记录下来提醒自己!
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~