MySQL字符串和数字比较
在项目中,我们经常会用到模糊搜索,但如果错误的将字符串类型和数字类型做比较,有时搜索出来的结果就并不是我们预期的。举例如下:
mybatis中的xml语句如下:
<if test="criteria != null and criteria.length()>0"> AND (name like concat("%",#{criteria},"%") OR id = #{criteria}) </if>
搜索时我们输入“884测试”,结果会包含了id=884的记录,但是名称却没有匹配的。这就是MySQL字符串和数字比较的坑了:比较时会把字符串类型转成整数类型,从首字母开始,遇到非数字类型后终止。
举几个例子看下:
SELECT "abc"=1; 结果:0
SELECT "1abc"=1; 结果:1
SELECT "abc"=0; 结果:1
SELECT "a2bc"=2; 结果:0
那么这个问题改如何解决了,其实只需要做一个类型转换就可以了,如下:
SELECT "2bc"=cast(2 as CHAR); 结果:0
欢迎订阅「K叔区块链」 - 专注于区块链技术学习
博客地址:http://www.jouypub.com
简书主页:https://www.jianshu.com/u/756c9c8ae984
segmentfault主页:https://segmentfault.com/blog/jouypub
腾讯云主页:https://cloud.tencent.com/developer/column/72548
相关推荐
LetonLIU 2020-03-28
东方咖啡屋 2020-02-14
LetonLIU 2019-12-23
qinkang 2019-11-09
surpassdream 2011-12-11
张浩BIT 2011-09-27
Franklyn 2017-01-01
hanyueqi 2019-06-30
康慧欣 2015-09-08
逆流而上的鲤鱼 2013-07-19
xhljames 2012-12-07
frank0 2012-08-14
longxx 2012-07-09
阳光丶不锈 2012-07-09
zhongranxu 2019-06-28
Lendor 2012-04-25