SQLServer的链接服务器技术小结
时间:2007-12-23 来源:不详 作者:迈克DB
安装MySQL的ODBC驱动MyODBC
1、为MySQL建立一个ODBC系统数据源,例如:选择数据库为test,数据源名称为myDSN
2、建立链接数据库
EXECsp_addlinkedserver@server=’MySQLTest’,@srvproduct=’MySQL’,
@provider=’MSDASQL’,@datasrc=’myDSN’
GO
EXECsp_addlinkedsrvlogin
@rmtsrvname=’MySqlTest’,@useself=’false’,@locallogin=’sa’,@rmtuser=’mys
ql的用户名’,@rmtpassword=’mysql的密码’
3、查询数据
SELECT*FROMOPENQUERY(MySQLTest,’select*from表’)
下面这个不行:
SELECT*FROMOPENQUERY(MySQLTest,’表’)
注重:不能直接用select*from链接服务器名.数据库名.用户名.表(或视图)
四部分名称查询数据,可能是个Bug.
二、使用MicrosoftOLEDBProviderForORACLE链接ORACLE
1、建立链接数据库
sp_addlinkedserver’别名’,’Oracle’,’MSDAORA’,’服务名’
GO
EXECsp_addlinkedsrvlogin@rmtsrvname=’别名 ’,@useself=’false’,@locallogin=’sa’,@rmtuser=’oracle用户名 ’,@rmtpassword=’密码’
内容来自dedecms
2、查询数据
SELECT*FROM别名..用户名.表(视图)
注重:四部分名称全部用大写
3、执行存储过程
使用OPENQUERY:
SELECT*
FROMOPENQUERY(别名,’exec用户名.存储过程名’)
三、设置链接服务器以访问格式化文本文件
用于Jet的MicrosoftOLEDB提供程序可用于访问并查询文本文件。
若要直接创建访问文本文件的链接服务器而不将文件链接为Access.mdb文件中的表,请行sp_addlinkedserver,如下例所示。
提供程序是Microsoft.Jet.OLEDB.4.0,提供程序字符串为"Text"。数据源是包含文本文件的目录的完整路径名称。schema.ini文件(描述文本文件的结构)必须与此文本文件存在于相同的目录中。有关创建schema.ini文件的更多信息,请参见Jet数据库引擎文档。
--Createalinkedserver.
EXECsp_addlinkedservertxtsrv,’Jet4.0’,
’Microsoft.Jet.OLEDB.4.0’,
’c:\data\distqry’,
NULL,
’Text’
GO
--Setuploginmappings.
EXECsp_addlinkedsrvlogintxtsrv,FALSE,NULL,Admin,NULL
GO
--Listthetablesinthelinkedserver.
EXECsp_tables_extxtsrv
dedecms.com
GO
--Queryoneofthetables:file1#txt
--usinga4-partname.
SELECT*
FROMtxtsrv...[file1#txt]
dedecms.com
上一篇:一些Select检索高级用法 下一篇:SQLServer密码安全追踪和存储
文章评论
共有位Admini5网友发表了评论 查看完整内容