ITPub博客

首页 > Linux操作系统 > Linux操作系统 > sql server的链接服务器技术小结(转)

sql server的链接服务器技术小结(转)

原创 Linux操作系统 作者:jcszjswkzhou 时间:2019-04-10 08:45:07 0 删除 编辑
一、使用 microsoft ole db provider for odbc 链接mysql
  安装mysql的odbc驱动myodbc
1、为mysql建立一个odbc系统数据源,例如:选择数据库为test ,数据源名称为mydsn
2、建立链接数据库
  exec sp_addlinkedserver @server = ’mysqltest’, @srvproduct=’mysql’,
  @provider = ’msdasql’, @datasrc = ’mydsn’
  go
  exec sp_addlinkedsrvlogin
  @rmtsrvname=’mysqltest’,@useself=’false’,@locallogin=’sa’,@rmtuser=’mys
  ql的用户名’,@rmtpassword=’mysql的密码’
3、查询数据
  select * from openquery (mysqltest ,’select * from 表’ )
  下面这个不行:
  select * from openquery (mysqltest ,’表’ )
  注意:不能直接用select * from 链接服务器名.数据库名.用户名.表(或视图)
  四部分名称查询数据,可能是个bug.
二、使用 microsoft ole db provider for oracle 链接oracle
1、建立链接数据库
 sp_addlinkedserver ’别名’, ’oracle’, ’msdaora’, ’服务名’
  go
 exec sp_addlinkedsrvlogin @rmtsrvname=’别名 ’,@useself=’false’,@locallogin=’sa’,@rmtuser=’oracle用户名 ’,@rmtpassword=’密码’
2、查询数据
  select * from 别名..用户名.表(视图)
  注意:四部分名称全部用大写
3、执行存储过程
  使用openquery:
  select *
  from openquery(别名, ’exec 用户名.存储过程名’)

三、设置链接服务器以访问格式化文本文件
  用于 jet 的 microsoft ole db 提供程序可用于访问并查询文本文件。
  若要直接创建访问文本文件的链接服务器而不将文件链接为 access .mdb 文件中的表,请行 sp_addlinkedserver,如下例所示。
  提供程序是 microsoft.jet.oledb.4.0,提供程序字符串为"text"。数据源是包含文本文件的目录的完整路径名称。schema.ini 文件(描述文本文件的结构)必须与此文本文件存在于相同的目录中。有关创建 schema.ini 文件的更多信息,请参见 jet 数据库引擎文档。
  --create a linked server.
  exec sp_addlinkedserver txtsrv, ’jet 4.0’,
  ’microsoft.jet.oledb.4.0’,
  ’c:datadistqry’,
  null,
  ’text’
  go
  --set up login mappings.
  exec sp_addlinkedsrvlogin txtsrv, false, null, admin, null
  go
  --list the tables in the linked server.
  exec sp_tables_ex txtsrv
  go
  --query one of the tables: file1#txt
  --using a 4-part name.
  select *
  from txtsrv...[file1#txt]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10294527/viewspace-122640/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2007-08-29

  • 博文量
    3488
  • 访问量
    2621674