本篇文章给大家带来的内容是关于mysql中字符串和数字的比较(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
在项目中,我们经常会用到模糊搜索,但如果错误的将字符串类型和数字类型做比较,有时搜索出来的结果就并不是我们预期的。举例如下:
mybatis中的xml语句如下:
0"> AND (name like concat("%",#{criteria},"%") OR id = #{criteria})
搜索时我们输入“884测试”,结果会包含了id=884的记录,但是名称却没有匹配的。这就是MySQL字符串和数字比较的坑了:比较时会把字符串类型转成整数类型,从首字母开始,遇到非数字类型后终止。
怪兽AI数字人
数字人短视频创作,数字人直播,实时驱动数字人
44 查看详情
举几个例子看下:
SELECT "abc"=1;结果:0
SELECT "1abc"=1;结果:1
SELECT "abc"=0;结果:1
SELECT "a2bc"=2;结果:0
那么这个问题改如何解决了,其实只需要做一个类型转换就可以了,如下:
SELECT "2bc"=cast(2 as CHAR);结果:0
以上就是MySQL中字符串和数字的比较(附示例)的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/379899.html
微信扫一扫
支付宝扫一扫