sql collate 子句 排序规则
Posted 一个自信的性格,一个放松的状态!
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql collate 子句 排序规则相关的知识,希望对你有一定的参考价值。
SQL SERVER的排序规则平时使用不是很多,也许不少初学者还比较陌生,但有
一个错误大家应是经常碰到: SQL SERVER数据库,在跨库多表连接查询时,若两数据
库默认字符集不同,系统就会返回这样的错误:
“无法解决 equal to 操作的排序规则冲突。”
COLLATE 是一个子句,可应用于数据库定义或列定义以定义排序规则,或应用于字符串表达式以应用排序规则转换。
语法
COLLATE { <collation_name> | database_default } <collation_name> :: = { Windows_collation_name } | { SQL_collation_name }
collation_name 应用于表达式、列定义或数据库定义的排序规则的名称。
database_default 使 COLLATE 子句继承当前数据库的排序规则。
一.错误分析:
这个错误是因为排序规则不一致造成的,我们做个测试,比如:
create table #t1( name varchar(20) collate Albanian_CI_AI_WS, value int) create table #t2( name varchar(20) collate Chinese_PRC_CI_AI_WS, value int ) 表建好后,执行连接查询: select * from #t1 A inner join #t2 B on A.name=B.name
这样,错误就出现了:
服务器: 消息 446,级别 16,状态 9,行 1
无法解决 equal to 操作的排序规则冲突。
要排除这个错误,最简单方法是,表连接时指定它的排序规则,这样错误就
不再出现了。语句这样写:
select * from #t1 A inner join #t2 B on A.name collate database_default=B.name collate database_default
select * from #t1 A inner join #t2 B on A.name =B.name collate database_default
语法规则 字段名后跟 collate database_default 建议用 collate database_default 这样的话 继承自 当前数据库排序规则 避免后续有不必要的麻烦
以上是关于sql collate 子句 排序规则的主要内容,如果未能解决你的问题,请参考以下文章
使用 CollationInfo.Comparer 在 c# 和 SQL 之间实现一致的排序
数据库字符集与排序规则(Character Set And Collation)
数据库排序规则的冲突(理解collate Chinese_PRC_CI_AS)
Cannot resolve the collation conflict between "Chinese_PRC_CI_AS" and "SQL_L及由于排序规则不同