MySQL 用数字对字符串值进行排序?

标签 mysql sql-order-by

我的数据是这样的:

KRYPTON-4xLV
KRYPTON-3xSTG
KRYPTON-16xTH
KRYPTON-8xTH
KRYPTON-8xLV

当我在此列上调用 ORDER BY 时,值按如下方式排序:

KRYPTON-16xTH
KRYPTON-3xSTG
KRYPTON-4xLV
KRYPTON-8xLV
KRYPTON-8xTH

有没有办法像这样排序?

KRYPTON-4xLV
KRYPTON-8xLV
KRYPTON-3xSTG
KRYPTON-8xTH
KRYPTON-16xTH

这是 SQL fiddle :http://sqlfiddle.com/#!9/6d061/2

最佳答案

尝试以下操作:

select code
from (select *, substring(code, LOCATE('-', code) + 1, length(code)) o from products )t
order by 
substring(o, LOCATE('x', o), length(code)),
cast(o as UNSIGNED)

关于MySQL 用数字对字符串值进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30568384/

相关文章:

mysql - R Mysql dbconnect 参数

php - MySQL 排序问题

mysql - 加入、分组、排序

sql - 按 XML 的不同大小写排序

php - mysql 结果首先显示一些产品,然后显示其余的

php 和 mysql,最佳实践

php - MySQL:获取开始和结束时间之间 TIME ('xx:yy:zz' ) 的记录

php - 如何让 PHPMyAdmin 显示 MySQL 警告?

android - 针对 Android 客户端请求优化 apache 和 mysql

mysql - 为什么在 MySQL 中使用 '' 或 ""不能通过 ORDER BY 对列别名进行排序?