[已解决]使用order by 排序后的是10 6 7 8 9 而不是 6 7 8 9 10?

简介: [已解决]使用order by 排序后的是10 6 7 8 9 而不是 6 7 8 9 10?

问题

sql order by 排序后的为什么 是10

6

7

8

9

而不是 6

7

8

9

10?

思路

在 SQL 中,ORDER BY 默认的排序方式是升序(从小到大)。所以,如果您简单地使用 ORDER BY 对某个列进行排序,它会将数字按照升序排列,即:

SELECT your_column
FROM your_table
ORDER BY your_column;

上面的语句会得到:

6
7
8
9
10

如果您得到的排序结果是 10, 6, 7, 8, 9,那可能是因为列的数据类型被当作字符串类型而非数字类型来排序。在字符串排序中,“10” 会在 “6” 前面,因为字符串排序是按照字符的字典顺序,而 “1” 的字典顺序在 “6” 之前。

为了确保数字按照数值大小来排序,您需要确保排序的列是数值类型(如 INTBIGINTDECIMAL 等)。如果列是字符串类型(如 VARCHARTEXT 等),并且您希望按数值排序,您可以尝试在 ORDER BY 子句中进行类型转换,例如:

SELECT your_column
FROM your_table
ORDER BY CAST(your_column AS INT);

这里的 CAST(your_column AS INT) 将字符串类型的列转换为整数类型,然后按照数值大小进行排序。如果列中含有无法转换为整数的字符串,这个查询将会失败,因此需要确保列中的所有值都是有效的整数字符串。

解决

将字符转换成int类型后成功解决!


目录
相关文章
orderBy排序,null在最后
orderBy排序,null在最后
214 0
|
SQL
解决union查询order by 排序失效的问题
解决union查询order by 排序失效的问题
238 0
|
SQL
ORDER BY:对查询结果进行排序
ORDER BY:对查询结果进行排序
111 0
ORDER BY子句
ORDER BY子句
61 0
|
SQL Oracle 关系型数据库
SQL学习之使用order by 按照指定顺序排序或自定义顺序排序
我们通常需要根据客户需求对于查询出来的结果给客户提供自定义的排序方式,那么我们通常sql需要实现方式都有哪些,参考更多资料总结如下(不完善的和错误望大家指出): 一、如果我们只是对于在某个程序中的应用是需要按照如下的方式排序,我们只需在SQL语句级别设置排序方式:
720 0
|
存储 关系型数据库 MySQL
Innodb:使用索引避免排序后DESC和ASC的区别
Innodb:使用索引避免排序后DESC和ASC的区别
125 0
Innodb:使用索引避免排序后DESC和ASC的区别
|
SQL 数据库
除了会排序,你对ORDER BY的用法可能一无所知!(一)
小伙伴们在进行SQL排序时,都能很自然的使用到ORDER BY。不管是默认ASC的升序,还是DESC降序,几乎都是信手拈来。 今天给大家分享一些你可能不知道的ORDER BY用法。
除了会排序,你对ORDER BY的用法可能一无所知!(一)
|
XML SQL 数据库
除了会排序,你对ORDER BY的用法可能一无所知!(二)
小伙伴们在进行SQL排序时,都能很自然的使用到ORDER BY。不管是默认ASC的升序,还是DESC降序,几乎都是信手拈来。 今天给大家分享一些你可能不知道的ORDER BY用法。
除了会排序,你对ORDER BY的用法可能一无所知!(二)
|
数据库
分页limit和排序order by
分页limit和排序order by
|
SQL 安全 数据库
使用order by排序判断返回结果的列数,order by排序判断字段数原理详解
order by排序猜解列数原理详解 一、order by的两种使用方式 1)按照字段名排序
604 0
使用order by排序判断返回结果的列数,order by排序判断字段数原理详解