mybatis动态sql,<if test=““>相同字段,数据类型为数值类型引发的问题

1. 背景

在写动态sql时,经常会用 <if test="">判断对象的字段是否为空或是否为空字符串

有一个场景:一个对象的字段,在动态sql中会使用两次

<where>
	<if test="dto.status != null and dto.status != ''">
		<!-- 片段1 -->
	</if>
	
	<if test="dto.status != null and dto.status != 1">
		<!-- 片段2 -->
	</if>
</where>

像上面一样,理想的结果就是当 status 同时符合条件时,可以拼接上片段1和片段2,但是观察实际sql并没有

2. 问题原因

调试了很久,最后突然发现 status 是 Long 类型!!!
也就是说,dto.status != ''永远都是false [ 捂脸 ]

最后把 dto.status != ''删除即可
写这篇文章,用于提醒自己,以后写动态sql时,要关注数据类型的字段!!!
而且如果是数据类型,就直接把 != ''给删除掉,以防下次直接拷贝出错

foreach 内嵌入 <trim prefix="(" suffix=")" suffixOverrides=","> <if test="searchValue != null">searchvalue,</if> <if test="createBy != null">createby,</if> <if test="createTime != null">createtime,</if> <if test="updateBy != null">updateby,</if> <if test="updateTime != null">updatetime,</if> <if test="remark != null">remark,</if> <if test="params != null">params,</if> <if test="id != null">id,</if> <if test="serialId != null and serialId != ''">serialid,</if> <if test="purchaserOrganizationId != null and purchaserOrganizationId != ''">purchaserorganizationid,</if> <if test="organizationId != null and organizationId != ''">organizationid,</if> <if test="vehicleId != null and vehicleId != ''">vehicleid,</if> <if test="purchaserOrganizationCode != null">purchaserorganizationcode,</if> <if test="erpPlantCd != null">erpplantcd,</if> <if test="materialCode != null">materialcode,</if> <if test="vehicleSeries != null">vehicleseries,</if> <if test="batchNo != null and batchno != ''">batchno,</if> <if test="arrivalYymm != null and arrivalYymm != ''">arrivalyymm,</if> <if test="quantity != null and quantity != ''">quantity,</if> <if test="contractNo != null and contractNo != ''">contractno,</if> <if test="lotNo != null and lotNo != ''">lotno,</if> <if test="itemId != null and itemId != ''">itemid,</if> <if test="itemCode != null">itemcode,</if> <if test="partDiv != null">partdiv,</if> <if test="kdType != null">kdtype,</if> <if test="pushFlag != null">pushflag,</if> </trim> <trim prefix="values (" suffix=")" suffixOverrides=","> <if test="searchValue != null">#{searchValue},</if> <if test="createBy != null">#{createBy},</if> <if test="createTime != null">#{createTime},</if> <if test="updateBy != null">#{updateBy},</if> <if test="updateTime != null">#{updateTime},</if> <if test="remark != null">#{remark},</if> <if test="params != null">#{params},</if> <if test="id != null">#{id},</if> <if test="serialId != null and serialId != ''">#{serialId},</if> <if test="purchaserOrganizationId != null and purchaserOrganizationId != ''">#{purchaserOrganizationId},</if> <if test="organizationId != null and organizationId != ''">#{organizationId},</if> <if test="vehicleId != null and vehicleId != ''">#{vehicleId},</if> <if test="purchaserOrganizationCode != null">#{purchaserOrganizationCode},</if> <if test="erpPlantCd != null">#{erpPlantCd},</if> <if test="materialCode != null">#{materialCode},</if> <if test="vehicleSeries != null">#{vehicleSeries},</if> <if test="batchNo != null and batchNo != ''">#{batchNo},</if> <if test="arrivalYymm != null and arrivalYymm != ''">#{arrivalYymm},</if> <if test="quantity != null and quantity != ''">#{quantity},</if> <if test="contractNo != null and contractNo != ''">#{contractNo},</if> <if test="lotNo != null and lotNo != ''">#{lotNo},</if> <if test="itemId != null and itemId != ''">#{itemId},</if> <if test="itemCode != null">#{itemCode},</if> <if test="partDiv != null">#{partDiv},</if> <if test="kdType != null">#{kdType},</if> <if test="pushFlag != null">#{pushFlag},</if> </trim>
最新发布
11-15
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lt0_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值