最近项目中遇到一个bug,正常的流程是这样的:要上传一个应用,首先检查系统中是否已经存在这个应用的更高版本,如果存在,则上传操作将被取消。
bug体现为当传入系统中存在的所有应用与新上传的应用的versioncode都小于10,则上传能够成功,而当传入一个versioncode=10的应用时判断存在更高版本,操作被取消。复现并定位这个问题以后,考虑到对比versioncode处的代码应该有问题,查看如下:
mapper.xml里有这样一句:
and t.versioncode >= #{versioncode}
这样转为sql后为:and t.versioncode>= "10",
也就是说这里进行了一次字符串的比较,比较的结果是9>'10'
知道问题的原因了,bug修改如下:
and t.versioncode >= ${versioncode}
这样转为sql后为:and t.versioncode>= 10,也就是说这里进行了一次数字的比较,比较的结果是9<10
问题解决了,希望同志们不要再出这样的bug喽,查找起来起来好麻烦的。。。