前几天项目中,遇到个问题,需要用到SQL跨服务器,跨数据库的连接。
考虑了下,直接连接的话肯定有问题,于是做了个存储过程,每天去拉数据.
环境如下:
提是我们已经知道远程服务器的地址,SQL用户名及密码:
密 码:1234567
登陆名:saa
地址:192.168.12.2
1. SA登录,或者有权限者 MASTER 数据库中,我们在查询分析器里面执行如下语句 .
--建立远程服务器连接
exec sp_addlinkedserver ''KQSQL'', ''ms'',''SQLOLEDB'',"192.168.12.2"
2.继续执行
--建立远程服务器登陆
exec sp_addlinkedsrvlogin ''KQSQL'',''false'', NULL,''saa'',''1234567''
--试验是否成功看执行能否建立新记录
--并且可以执行以下语句进行验证
--select * from KQSQL.sqlcch.dbo.pb_emply
注意:这里的KQSQL就是我命名的一个远程连接名, saa是用户名 pb_emply是表名.
--能获取到数据了,表示跨服务器连接已经成功
--下面的语句是要删除相应的连接记录(原来有连接了,但是连接不对的情况下).
--exec sp_dropserver ''KQSQL'',''droplogins''