首页 > 数据库 > SQL > 正文

SQL排序规则怎么设置_关键概念讲透让学习更加顺畅【技巧】

冰川箭仙
发布: 2025-12-23 22:37:02
原创
588人浏览过
SQL排序规则(Collation)决定字符比较和排序的底层逻辑,影响大小写、重音敏感性及中文排序方式,可在列级、表达式级、数据库级和服务器级设置,高优先级覆盖低优先级。

sql排序规则怎么设置_关键概念讲透让学习更加顺畅【技巧】

SQL排序规则(Collation)不是ORDER BY本身,而是决定“怎么比大小”的底层设定。它影响字符比较、排序顺序、是否区分大小写和重音——这些在你用ORDER BY时悄悄起作用,但很多人直到排序结果“不对劲”才意识到问题出在这儿。

排序规则到底管什么

它不控制你写不写DESC,也不决定先排哪个字段。它管的是:

  • 字母A和a算不算相等(大小写敏感:CI vs CS)
  • café和cafe排在一起还是分开(重音敏感:AI vs AS)
  • 中文按拼音、笔画还是Unicode码点排(如Chinese_PRC_CI_AS vs Latin1_General_CI_AS)
  • 同一个查询,在不同服务器上ORDER BY 'apple'和'Apple'谁在前,可能结果相反

在哪一级可以设置

排序规则可设在四个层级,优先级从高到低:

  • 列级:建表时指定,最精准。例:name VARCHAR(50) COLLATE Chinese_PRC_CI_AS
  • 表达式级:查询中临时覆盖,用COLLATE关键字。例:ORDER BY username COLLATE SQL_Latin1_General_CP1_CI_AS
  • 数据库级:创建DB时指定,默认影响所有新列(除非显式覆盖)
  • 服务器级:安装SQL Server时定下,是整个实例的兜底规则

注意:高优先级会覆盖低优先级。比如某列设了CS(区分大小写),即使数据库是CI(不区分),该列仍按CS比对。

常见排序规则命名含义

Chinese_PRC_CI_AS为例拆解:

Blogcast™
Blogcast™

BlogcastTM是一个文本转语音的工具,允许用户创建播客、视频、电子学习课程的音频和音频书籍,而无需录制。

Blogcast™ 63
查看详情 Blogcast™
  • Chinese_PRC:语言区域(中国大陆中文)
  • CI:Case Insensitive(不区分大小写)
  • AS:Accent Sensitive(区分重音)

再比如SQL_Latin1_General_CP1_CI_AS,CP1代表代码页1252,适合西欧字符;而Latin1_General_100_CI_AS_SC_UTF8支持UTF-8且带补充字符(SC)支持。选错可能导致中文乱序、emoji无法比较等问题。

什么时候要特别注意

以下情况容易暴露排序规则问题:

  • 跨库JOIN或UNION时提示“无法解析排序规则冲突”
  • ORDER BY中文字段,结果不是按拼音顺序(比如“北京”排在“上海”后面)
  • WHERE name = 'Tom' 查不到'tom',但明明设了CI——可能列级用了CS
  • 同一SQL在开发环境正常,上线后排序颠倒(服务器默认规则不同)

查当前列的排序规则,可用:SELECT collation_name FROM sys.columns WHERE object_id = OBJECT_ID('表名') AND name = '列名';

基本上就这些。排序规则不是每次写ORDER BY都要调,但一旦遇上字符排序异常,它就是根因。理解它,比死记语法更能避开大坑。

以上就是SQL排序规则怎么设置_关键概念讲透让学习更加顺畅【技巧】的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号