2016-11-08 65 views
0

我仍然得到錯誤代碼SQL服務器:無法解析排序規則衝突,儘管轉換

無法解析「Latin1_General_CI_AS」 並在等於操作規則「SQL_Latin1_General_CP1_CI_AS」之間的排序規則衝突。

儘管事實上我使用的轉換按照these兩個answers。這裏是我的代碼:

-- ... 
from #TmpResult a 
left join #GroupMemberTable b 
on (a.DBO_Owner_Login COLLATE SQL_Latin1_General_CP1_CI_AS) = (b.login_name COLLATE SQL_Latin1_General_CP1_CI_AS) 

我讓他們都轉換爲:SQL_Latin1_General_CP1_CI_AS

謝謝

UPDATE: 以下是完整的摘錄:

create table #TmpTableSec3 (database_name varchar(100), Database_Owner varchar(200), DBO_Owner_Login varchar(200), type varchar (100), privilege varchar(100), group_name varchar(500)) 
insert into #TmpTableSec3 
select a.database_name, a.principal, a.DBO_Owner_Login, b.type, b.privilege, b.group_name 
from #TmpResult a 
left join #GroupMemberTable b 
on (a.DBO_Owner_Login COLLATE SQL_Latin1_General_CP1_CI_AS) = (b.login_name COLLATE SQL_Latin1_General_CP1_CI_AS) 
    --a.DBO_Owner_Login = b.login_name 
    --fieldname COLLATE DATABASE_DEFAULT = otherfieldname COLLATE DATABASE_DEFAULT 
where b.group_name is not null --and b.privilege = 'admin' 
order by a.database_name 

然後該表填充爲:

insert into #TmpResult 
select a.database_name, a.Owner, b.DBO_Owner_Login from #TmpTableSec1 a 
join #TmpTableSec2 b 
on a.database_name = b.database_name 


    set @cmd = 'select name, suser_sname(owner_sid) from master.sys.databases where name = '''[email protected]+'''' 
    --select @cmd 
    insert #TmpTableSec1 exec (@cmd) 
    --select @dbowner = (select suser_sname(owner_sid) from master.sys.databases where name = @name) 
    set @cmd = 'use '+ @name +' 
    select db_name(), name, suser_sname(sid) 
    from sys.database_principals where name = ''dbo''' 
    --select ''@DBO'' = (select suser_sname(sid) from sys.database_principals where name = ''dbo'') ' 
    INSERT #TmpTableSec2 exec (@cmd) 
+4

問題可能是在''.....你的代碼的一部分 – Lamak

+1

請張貼您嘗試執行 – NickyvV

+0

@NickyvV我貼得更整個代碼,但我認爲這個問題是隻與該行相關 – LearnByReading

回答

0
drop table #test 
drop table #test2 

create table #test 
(id int, name varchar(100) collate Latin1_General_CI_AI 
CONSTRAINT [PK_test] PRIMARY KEY CLUSTERED ([id] ASC) 
) 

create table #test2 
(id int, name varchar(100) collate SQL_Latin1_General_CP1_CI_AS 
CONSTRAINT [PK_test2] PRIMARY KEY CLUSTERED ([id] ASC) 
) 

insert into #test values (1, 'premonition') 
insert into #test values (2, 'premònition') 
insert into #test values (3, 'lowmotion') 

insert into #test2 values (1, 'premonition') 
insert into #test2 values (2, 'premònition') 
insert into #test2 values (3, 'lowmotion') 

select * 
from #test 
inner join #test2 
    on #test.name = #test2.name collate SQL_Latin1_General_CP1_CI_AS 

collate SQL_Latin1_General_CP1_CI_AS強制與此相比整理,我用了#test2.name

定義相同的排序規則也許這個「整理優先」的文章可以幫助你。

https://msdn.microsoft.com/en-us/library/ms179886.aspx

相關問題