sql 怎么对带单位字符串排序?
表中有个字段size带单位M, 假如有记录 50M 40M 20M,怎么写sql查询出所有大于30M的记录?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
表中有个字段size带单位M, 假如有记录 50M 40M 20M,怎么写sql查询出所有大于30M的记录?
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(1)
要知道 sql 对于 varchar 的排序是字符序,它会从字符串的第一位开始进行 ascii 码的比较。
所以 30M < 40M,而301M < 40M。
如果你的单位是固定位数的话,可以用 mysql 的截取字符串函数,把单位去掉之后再进行过滤筛选。
如 select * from table where cast(substring_index(size,’M’,1) as signed) > 40
这个 sql 的意思是取这一列第一个 M 之前的字符并转化为整数,并且转化后的整数大于40。
当然这样写,列名用了函数就没法走索引了,数据量大的话会比较慢。
以上。