SQL SERVER数据库,在跨库多表连接查询时,若两数据
库默认字符集不同,系统就会返回这样的错误:

       “无法解决 equal to 操作的排序规则冲突。”

COLLATE 是一个子句,可应用于数据库定义或列定义以定义排序规则,或应用于字符串表达式以应用排序规则转换。

语法:

COLLATE {  | database_default }
 :: = 
     { Windows_collation_name } | { SQL_collation_name }

collation_name 应用于表达式、列定义或数据库定义的排序规则的名称。

database_default 使 COLLATE 子句继承当前数据库的排序规则。

一.错误分析:
  这个错误是因为排序规则不一致造成的
错误提示通常如下:

           服务器: 消息 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 这样的话 继承自 当前数据库排序规则 避免后续有不必要的麻烦