MySQL中数字字符串的大小比较

本文揭示了一个在SQL中处理字符串排序时容易忽略的问题:当字符串包含数字时,排序默认按照数字的末位进行比较,而非整体数值大小。文章通过示例说明了这一现象,并提供了解决方案——在ORDER BY子句中将参考列转换为数字。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SQL中字符串比较大小是个比较坑的事儿。如果你觉得字符串类型的10比9大那就不小心被坑了。其实是这样的:

看到了吗,我们把内容为1-10的字符串升序排序,结果发现10并未出现在第一行而是倒数第二行。这是因为字符串中是数字时是按照最后一位比较的,解决方法也很简单——+0。就像这样:


在order by的参考列上+0即可解决这个问题。问题很小却很精妙。最后列出本表。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值