首页 > 其他 > 详细

创建link server链接服务器碰到的问题及解决办法

时间:2015-09-10 19:07:34      阅读:267      评论:0      收藏:0      [点我收藏+]

问题描述

今天在做数据库迁移,然后新建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 = NHP580DBSZ)EXEC master.dbo.sp_dropserver @server=NHP580DBSZ, @droplogins=droplogins
GO
/****** Object:  LinkedServer [HP580DBSZ]    Script Date: 09/10/2015 17:25:22 ******/
EXEC master.dbo.sp_addlinkedserver @server = NHP580DBSZ, @srvproduct=NHP580DBSZ, @provider=NSQLNCLI10, @datasrc=NHP580DBSZ\DEV
 /* For security reasons the linked server remote logins password is changed with ######## */
EXEC master.dbo.sp_addlinkedsrvlogin @rmtsrvname=NHP580DBSZ,@useself=NFalse,@locallogin=NULL,@rmtuser=Nsa,@rmtpassword=ctrip.hp580dbsz.dev
GO

创建link server链接服务器碰到的问题及解决办法

原文:http://www.cnblogs.com/mcgrady/p/4798609.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!