Mysql字符varchar过度匹配查询条件Long

CREATE TABLE `test` (
  `id` int(11) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  `password` varchar(255) DEFAULT NULL,
  `a` varchar(32) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ;

已知有3条不同a值的数据

但语句 

SELECT * FROM `test` where a = 99233720368547758074444;

却能查出多条,是变模糊匹配了?还是转换失败了?

这是怎么一个实现过程呢,很好奇,首先想到的是字段类型转化问题

然后是来验证这个想法,测试了以下几个猜测:

  1. 字段超过某个长度就一定匹配吗?                        结果:不是
  2. 查询条件长度超过多少位会产生这个问题?         结果:20位
  3. 匹配到的数据条长度可以不一样长?                    结果:不是
  4. 可以把字段varchar中数字改成字母吗?               结果:不可以

根据以上结果,得出初步结论:如果按超过20位数值查询varchar类型的字段,字段会把字段值按前20位转化为数值来匹配查询条件,但不能是字母,这个操作好像只适用数字。

当然,完善结论会需要更多测试

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值