小弟求救。无法解决 equal to 操作的排序规则冲突的错误。详情请见正文。

CeleronII 2005-04-23 02:29:40
create table temp(classID varchar(50),currentClass varchar(50),parentClassID varchar(50),level varchar(50)) insert into temp select classID,currentClass,parentClassID,1 level from T_class where (parentClassID='' or parentClassID is null) and SSYW='2' union all select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID insert into temp select b.classID,b.currentClass,b.parentClassID,level+1 from temp a,T_class b where a.classID=b.parentClassID select distinct classID,currentClass,parentClassID,level from temp drop table temp。
这句SQL执行后就报:无法解决 equal to 操作的排序规则冲突。请求高手解决。
...全文
119 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
paoluo 2005-04-23
  • 打赏
  • 举报
回复
在企业管理中的,选中表,设计表,你就可以看到排序规则这项了,修改为你想要的即可。
CeleronII 2005-04-23
  • 打赏
  • 举报
回复
谢谢兄弟,我以前的表建立的默认排序规格都为Chinese_PRC_CI_AS,我现在想把以前建的表的排序规则更改为Chinese_PRC_CI_AI,请问如何修改。
paoluo 2005-04-23
  • 打赏
  • 举报
回复
一.错误分析:
  这个错误是因为排序规则不一致造成的,我们做个测试,比如:
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
参考
http://community.csdn.net/Expert/FAQ/FAQ_Index.asp?id=3551

34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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