sqlserver链接服务器使用方法
分类: database2009-03-30 19:05 3737人阅读 评论(2) 收藏 举报
使用sql语句:
exec sp_addlinkedserver @server='serverontest',@provider='sqloledb',@srvproduct='',@datasrc='101.123.10.112'
添加一个链接服务器 
使用sql语句:
EXEC sp_addlinkedsrvlogin @rmtsrvname = 'serverontest', @useself = 'false', @locallogin = 'sa', @rmtuser = 'sa', @rmtpassword = 'passwordofsa'
添加登录方式 
以上两个语句中,@server为服务器的别名,@datasrc为要链接的目标数据库的连接串,@rmtsrvname为别名,@locallogin为本地登录的用户名,@rmtuser@rmtpassword为要链接的目标数据库的登录用户名和密码 
添加完链接服务器之后,可以通过select * from sys.linked_logins select * from sys.servers来查看已经添加的链接服务器和登录角 
添加完链接服务器后,使用select * from 别名.库名.dbo.表名 来对其中的数据进行查询 
删除链接服务器登录映射和链接服务器的方法: 
  exec sp_droplinkedsrvlogin ’serverontest’ ,’sa’  
  exec sp_dropserver ’serverontest’ 
上文仅仅是添加到sqlserver的链接服务器的方法,关于添加到其它数据库的链接服务器的方法,参见: 
[c-sharp] view plaincopy
1.     一、使用 Microsoft OLE DB Provider For ODBC 链接MySQL   
2.   安装MySQLODBC驱动MyODBC 
3. 1、为MySQL建立一个ODBC系统数据源,例如:选择数据库为test ,数据源名称为myDSN 
4. 2、建立链接数据库 
5.   EXEC sp_addlinkedserver @server = ’MySQLTest’, @srvproduct=’MySQL’, 
6.   @provider = ’MSDASQL’, @datasrc = ’myDSN’ 
7.   GO 
8.   EXEC sp_addlinkedsrvlogin 
9.   @rmtsrvname=’MySqlTest’,@useself=’false’,@locallogin=’sa’,@rmtuser=’mys 
10.   ql的用户名’,@rmtpassword=’mysql的密码’ 
11. 3、查询数据 
12.   SELECT * FROM OPENQUERY (MySQLTest ,’select * from ’ ) 
13.   下面这个不行
14.   SELECT * FROM OPENQUERY (MySQLTest ,’’ ) 
15.   注意:不能直接用select * from 链接服务器名.数据库名.用户名.(或视图
16.   四部分名称查询数据,可能是个Bug. 
17. 二、使用 Microsoft OLE DB Provider For ORACLE 链接ORACLE 
18. 1、建立链接数据库 
19.  sp_addlinkedserver ’别名’, ’Oracle’, ’MSDAORA’, ’服务名’ 
20.   GO 
21.  EXEC sp_addlinkedsrvlogin @rmtsrvname=’别名 ’,@useself=’false’,@locallogin=’sa’,@rmtuser=’oracle用户名 ’,@rmtpassword=’密码’ 
22. 2、查询数据 
23.   SELECT * FROM 别名..用户名.(视图
24.   注意:四部分名称全部用大写 
25. 3、执行存储过程 
26.   使用OPENQUERY: 
27.   SELECT * 
28.   FROM OPENQUERY(别名, ’exec 用户名.存储过程名’)   
29.      
30. 三、设置链接服务器以访问格式化文本文件 
31.   用于 Jet sql连接不上服务器的 Microsoft OLE DB 提供程序可用于访问并查询文本文件。 
32.     若要直接创建访问文本文件的链接服务器而不将文件链接为 Access .mdb 文件中的表,请行 sp_addlinkedserver,如下例所示。 
33.   提供程序是 Microsoft.Jet.OLEDB.4.0,提供程序字符串为"Text"。数据源是包含文本文件的目录的完整路径名称。 schema.ini 文件(描述文本文件的结构)必须与此文本文件存在于相同的目录中。有关创建 schema.ini 文件的更多信息,请参见 Jet 数据库引擎文档。 
34.   --Create a linked server. 
35.   EXEC sp_addlinkedserver txtsrv, ’Jet 4.0’, 
36.   ’Microsoft.Jet.OLEDB.4.0’, 
37.   ’c:/data/distqry’, 
38.   NULL, 
39.   ’Text’ 
40.   GO 
41.   --Set up login mappings. 
42.   EXEC sp_addlinkedsrvlogin txtsrv, FALSE, NULL, Admin, NULL 
43.   GO 
44.   --List the tables in the linked server. 
45.   EXEC sp_tables_ex txtsrv 
46.   GO 
47.   --Query one of the tables: file1#txt 
48.   --using a 4-part name. 
49.   SELECT * 
50.   FROM&[file1#txt] 
51.     四、链接SQL Server服务器:   
52. 1、使用 ODBC  Microsoft OLE DB 提供程序   
53.   EXEC sp_addlinkedserver ’别名’,’’,’MSDASQL’,NULL,NULL,’DRIVER={SQL  Server};SERVER=远程名;UID=用户;PWD=密码;’   
54.   如果加上参数@catalog,可以指定数据库   
55.   exec sp_addlinkedsrvlogin @rmtsrvname=’别名  ’,@useself=’false’,@locallogin=’sa’,@rmtuser=’sa’,@rmtpassword=’密码’   
56. 2、使用SQL Server  Microsoft OLE DB 提供程序   
57.   exec sp_addlinkedserver @server=’别名  ’,@provider=’sqloledb’,@srvproduct=’’,@datasrc=’远程服务器名’   
58.   exec sp_addlinkedsrvlogin   
59.   @rmtsrvname=’wzb’,@useself=’false’,@locallogin=’sa’,@rmtuser=’sa’,@rmtp   
60.   assword=’密码’   
61.   然后你就可以如下:   
62.   select * from 别名.库名.dbo.表名   
63.   insert 库名.dbo.表名 select * from 别名.库名.dbo.表名   
64.   select * into 库名.dbo.新表名 from 别名.库名.dbo.表名   
65.   go   
66.   例1   
67.   此示例在 SQL Server 的实例上创建一台名为 S1_instance1 的链接服务器,   
68.   该服务器使用 SQL Server  Microsoft OLE DB 提供程序。  EXEC sp_addlinkedserver @server=’S1_instance1’, @srvproduct=’’,  @provider=’SQLOLEDB’,  @datasrc=’S1/instance1’   
69.   例2   
70.   --建立链接服务器   
71.   EXEC sp_addlinkedserver ’xiaoming’,’’,’MSDASQL’,NULL,NULL,’DRIVER={SQL   
72.   Server};SERVER=192.168.0.1;UID=sa;PWD=123;’   
73.   --建立链接服务器登录映射   
74.   exec sp_addlinkedsrvlogin   
75.   @rmtsrvname=’xiaoming’,@useself=’false’,@locallogin=’sa’,@rmtuser=’sa’,   
76.   @rmtpassword=’123’   
77.   go   
78.   --查询数据   
79.   select * from xiaoming.schooladmin.dbo.agent   
80.   --删除链接服务器登录映射和链接服务器:   
81.   exec sp_droplinkedsrvlogin ’xiaoming’ ,’sa’   
82.   exec sp_dropserver ’xiaoming’   
83.   注意事项:   
84.   SET IDENTITY_INSERT [ database.[ owner.] ] { table } { ON | OFF }   
85.   所以不能通过连接服务器设置此属性   
86.   into 也存在这样的问题   
87.   select * into& from   
88.    

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。