·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> 创建linkserver链接服务器碰到的问题及解决办法
今天在做数据库迁移,然后新建link server(链接服务器)的时候,碰到以下问题。
我的sql 脚本是这样的。
然后,执行的时候就收到以下错误信息。
Msg 468, Level 16, State 9, Line 7
Cannot resolve the collation conflict between "Latin1_General_CI_AS" and "SQL_Latin1_General_CP1_CI_AS" in the equal to Operation.
依据错误提示信息,很容易就可以发现,是因为当前DB的排序规则与链接服务器对应的DB的排序规则不一致导致的。
但是,确认当前DB的排序规则与链接服务器对的DB的排序规则是完全一样的,都是SQL_Latin1_General_CP1_CI_AS。
当然,我这里的解决办法只是一个替代的解决方案。
由于前面我是通过UI操作去创建的,那么我换一种方案,使用sql脚本(可以找一个正常的link server右键导出脚本然后修改)来创建,结果一切正常。
创建link server的脚本:
/****** Object: LinkedServer [HP580DBSZ] Script Date: 09/10/2015 17:25:22 ******/ IF EXISTS (SELECT srv.name FROM sys.servers srv WHERE srv.server_id != 0 AND srv.name = N'HP580DBSZ')EXEC master.dbo.sp_dropserver @server=N'HP580DBSZ', @droplogins='droplogins' GO /****** Object: LinkedServer [HP580DBSZ] Script Date: 09/10/2015 17:25:22 ******/ EXEC master.dbo.sp_addlinkedserver @server = N'HP580DBSZ', @srvPRoduct=N'HP580DBSZ', @provider=N'SQLNCLI10', @datasrc=N'HP580DBSZ\DEV' /* For security reasons the linked server remote logins passWord is changed with ######## */ EXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname=N'HP580DBSZ',@useself=N'False',@locallogin=NULL,@rmtuser=N'sa',@rmtpassword='ctrip.hp580dbsz.dev' GO