MySQL 设置为 varchar(255) 的列的排序问题
MySQL problem in the sorting of column set as varchar(255)
我无法将字段 sID_contents_p
设置为 VARCHAR (255)
,形成 table ttt
存储的数据库 MySql version 8.0.17
这是 db-fiddle.com 的结果,提供 MySQL 8
我需要这个 return,例如当 sID_contents_p
包含 1
+----------------+-----+
| sID_contents_p | sID |
+----------------+-----+
| 1.1 | 1 |
| 1.2 | 2 |
| 1.3 | 3 |
| 1.4 | 4 |
| 1.5 | 5 |
| 1.6 | 6 |
| 1.7 | 7 |
| 1.8 | 8 |
| 1.9 | 9 |
| 1.10 | 10 |
| 1.11 | 11 |
| 1.12 | 12 |
| 1.13 | 13 |
| 1.14 | 14 |
| 1.15 | 15 |
| 1.16 | 16 |
| 1.17 | 17 |
| 1.18 | 18 |
| 1.19 | 19 |
| 1.20 | 89 |
+----------------+-----+
我试过这个查询,但 return 不是您想要的(见上文)...
mysql> SELECT
sID_contents_p,
sID
FROM
`ttt` WHERE SUBSTRING_INDEX(sID_contents_p,".",1) = 1
ORDER BY
sID_contents_p ASC;
+----------------+-----+
| sID_contents_p | sID |
+----------------+-----+
| 1.1 | 1 |
| 1.10 | 10 |
| 1.11 | 11 |
| 1.12 | 12 |
| 1.13 | 13 |
| 1.14 | 14 |
| 1.15 | 15 |
| 1.16 | 16 |
| 1.17 | 17 |
| 1.18 | 18 |
| 1.19 | 19 |
| 1.2 | 2 |
| 1.20 | 89 |
| 1.3 | 3 |
| 1.4 | 4 |
| 1.5 | 5 |
| 1.6 | 6 |
| 1.7 | 7 |
| 1.8 | 8 |
| 1.9 | 9 |
+----------------+-----+
20 rows in set (0.03 sec)
问题出在顺序上。你有一个字符串。一种方法是先按长度排序:
ORDER BY LENGTH(sID_contents_p), sID_contents_p
编辑:
如果第一个组件的长度也可以变化,则拆分值并转换为整数:
ORDER BY SUBSTRING_INDEX(sID_contents_p, '.', 1) + 0,
SUBSTRING_INDEX(sID_contents_p, '.', -1) + 0
我无法将字段 sID_contents_p
设置为 VARCHAR (255)
,形成 table ttt
存储的数据库 MySql version 8.0.17
这是 db-fiddle.com 的结果,提供 MySQL 8
我需要这个 return,例如当 sID_contents_p
包含 1
+----------------+-----+
| sID_contents_p | sID |
+----------------+-----+
| 1.1 | 1 |
| 1.2 | 2 |
| 1.3 | 3 |
| 1.4 | 4 |
| 1.5 | 5 |
| 1.6 | 6 |
| 1.7 | 7 |
| 1.8 | 8 |
| 1.9 | 9 |
| 1.10 | 10 |
| 1.11 | 11 |
| 1.12 | 12 |
| 1.13 | 13 |
| 1.14 | 14 |
| 1.15 | 15 |
| 1.16 | 16 |
| 1.17 | 17 |
| 1.18 | 18 |
| 1.19 | 19 |
| 1.20 | 89 |
+----------------+-----+
我试过这个查询,但 return 不是您想要的(见上文)...
mysql> SELECT
sID_contents_p,
sID
FROM
`ttt` WHERE SUBSTRING_INDEX(sID_contents_p,".",1) = 1
ORDER BY
sID_contents_p ASC;
+----------------+-----+
| sID_contents_p | sID |
+----------------+-----+
| 1.1 | 1 |
| 1.10 | 10 |
| 1.11 | 11 |
| 1.12 | 12 |
| 1.13 | 13 |
| 1.14 | 14 |
| 1.15 | 15 |
| 1.16 | 16 |
| 1.17 | 17 |
| 1.18 | 18 |
| 1.19 | 19 |
| 1.2 | 2 |
| 1.20 | 89 |
| 1.3 | 3 |
| 1.4 | 4 |
| 1.5 | 5 |
| 1.6 | 6 |
| 1.7 | 7 |
| 1.8 | 8 |
| 1.9 | 9 |
+----------------+-----+
20 rows in set (0.03 sec)
问题出在顺序上。你有一个字符串。一种方法是先按长度排序:
ORDER BY LENGTH(sID_contents_p), sID_contents_p
编辑:
如果第一个组件的长度也可以变化,则拆分值并转换为整数:
ORDER BY SUBSTRING_INDEX(sID_contents_p, '.', 1) + 0,
SUBSTRING_INDEX(sID_contents_p, '.', -1) + 0