sql 怎么对带单位字符串排序?

发布于 2022-09-12 02:56:19 字数 62 浏览 22 评论 0

表中有个字段size带单位M, 假如有记录 50M 40M 20M,怎么写sql查询出所有大于30M的记录?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

千纸鹤 2022-09-19 02:56:19

要知道 sql 对于 varchar 的排序是字符序,它会从字符串的第一位开始进行 ascii 码的比较。

所以 30M < 40M,而301M < 40M。

如果你的单位是固定位数的话,可以用 mysql 的截取字符串函数,把单位去掉之后再进行过滤筛选。

如 select * from table where cast(substring_index(size,’M’,1) as signed) > 40

这个 sql 的意思是取这一列第一个 M 之前的字符并转化为整数,并且转化后的整数大于40。

当然这样写,列名用了函数就没法走索引了,数据量大的话会比较慢。

以上。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文