MySql数据库,对varchar类型字段str进行where str=0条件查询时,查询结果是什么

在用MySql查询数据的时候,遇到了一个奇怪的问题。用一个varchar类型的字符串str,作为条件与0比较时,会查str不为0的数据。

比如:select * from tb where str=0;会查到str为'0','0abc','abc'等数据。不符合查询的条件啊。

原因如下:

MySql在比较varchar类型和0的时候,会把varchar类型转换成数字0。

所以用str=0作为条件时,会把以0开头的字符串和普通字符串都转换成0。(比如:0abc,0,abc)

只排除一些以非0开头的字符串。(比如:1abc)

同理,查询str=1的数据,也会排除开头非1的字符串。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值