MySQL 中数字混合字符串的按字母数字顺序排序


假设你在一个表中有一个 VARCHAR 列,其值为字符串,数字在右侧。例如 -

John1023
Carol9871
David9098

现在,假设你要根据整个列右侧的数字进行排序。为此,请使用 ORDER BY RIGHT。

让我们首先创建一个表 -

mysql> create table DemoTable757 (
   Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   ClientId varchar(100)
);
Query OK, 0 rows affected (0.53 sec)

使用 insert 命令在表中插入一些记录 -

mysql> insert into DemoTable757(ClientId) values('John1023');
Query OK, 1 row affected (0.41 sec)
mysql> insert into DemoTable757(ClientId) values('Carol9871');
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable757(ClientId) values('David9098');
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable757(ClientId) values('Adam9989');
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable757(ClientId) values('Bob9789');
Query OK, 1 row affected (0.20 sec)

使用 select 语句从表中显示所有记录 -

mysql> select *from DemoTable757;

这将生成以下输出 -

+----+-----------+
| Id | ClientId  |
+----+-----------+
|  1 | John1023  |
|  2 | Carol9871 |
|  3 | David9098 |
|  4 | Adam9989  |
|  5 | Bob9789   |
+----+-----------+
5 rows in set (0.00 sec)

以下是 MySQL 中按字母数字排序的查询 -

mysql> select Id,ClientId from DemoTable757 order by right(ClientId,4);

这将生成以下输出 -

+----+-----------+
| Id | ClientId  |
+----+-----------+
|  1 | John1023  |
|  3 | David9098 |
|  5 | Bob9789   |
|  2 | Carol9871 |
|  4 | Adam9989  |
+----+-----------+
5 rows in set (0.00 sec)

更新于: 03-Sep-2019

467 浏览

开启你的 职业生涯

通过完成课程获取认证

立即开始
广告