MySQL中字符串和数字的比较(附示例)

不言
发布: 2018-12-21 10:22:13
转载
4021 人浏览过

本篇文章给大家带来的内容是关于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
登录后复制

以上是MySQL中字符串和数字的比较(附示例)的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:segmentfault.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!