前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[已解决]使用order by 排序后的是10 6 7 8 9 而不是 6 7 8 9 10?

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

作者头像
Maynor
发布2023-11-16 09:15:55
1780
发布2023-11-16 09:15:55
举报
文章被收录于专栏:最新最全的大数据技术体系

问题

sql order by 排序后的为什么 是10 6 7 8 9

而不是 6 7 8 9 10?

image-20231115111452625
image-20231115111452625

思路

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

代码语言:javascript
复制
SELECT your_column
FROM your_table
ORDER BY your_column;

上面的语句会得到:

代码语言:javascript
复制
6
7
8
9
10

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

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

代码语言:javascript
复制
SELECT your_column
FROM your_table
ORDER BY CAST(your_column AS INT);

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

解决

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

image-20231115111529772
image-20231115111529772
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-11-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题
  • 思路
  • 解决
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档