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

灿烂阳光168 2009-06-08 01:29:32
运行如下代码:

SELECT *
FROM Problem a INNER JOIN
emp b ON a.AuthorID = b.[No] INNER JOIN
train c ON a.CourseID = c.[no]

出现如下错误:

服务器: 消息 446,级别 16,状态 9,行 1
无法解决 equal to 操作的排序规则冲突。
...全文
59 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
ai_li7758521 2009-06-08
  • 打赏
  • 举报
回复
一.错误分析:   
  这个错误是因为排序规则不一致造成的,我们做个测试,比如:
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=B.name collate Chinese_PRC_CI_AI_WS
nzperfect 2009-06-08
  • 打赏
  • 举报
回复

  SELECT * 
FROM Problem a
INNER JOIN emp b ON a.AuthorID collate Chinese_PRC_CI_AS = b.[No] collate Chinese_PRC_CI_AS
INNER JOIN train c ON a.CourseID collate Chinese_PRC_CI_AS = c.[no] collate Chinese_PRC_CI_AS
csdyyr 2009-06-08
  • 打赏
  • 举报
回复
--try2
SELECT *
FROM Problem a INNER JOIN
emp b ON CAST(a.AuthorID AS INT) = CAST(b.[No] AS INT) INNER JOIN
train c ON a.CourseID = c.[no]
sdhdy 2009-06-08
  • 打赏
  • 举报
回复
1、看看这几个连接字段的类型
2、看看表的排序规则是否一样。
csdyyr 2009-06-08
  • 打赏
  • 举报
回复

--try
SELECT *
FROM Problem a INNER JOIN
emp b ON a.AuthorID = b.[No] INNER JOIN
train c ON a.CourseID = c.[no] COLLATE Chinese_PRC_CI_AS

22,206

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧