加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

范例比较MySQL中字符串和数字

发布时间:2023-10-19 16:11:20 所属栏目:MySql教程 来源:
导读:在项目中,我们经常会用到模糊搜索,但如果错误的将字符串类型和数字类型做比较,有时搜索出来的结果就并不是我们预期的。举例如下:

mybatis中的xml语句如下:

<if test="criteria != null and criteria.le
在项目中,我们经常会用到模糊搜索,但如果错误的将字符串类型和数字类型做比较,有时搜索出来的结果就并不是我们预期的。举例如下:
 
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
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章