博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQLServer跨库查询--分布式查询[转载]
阅读量:6118 次
发布时间:2019-06-21

本文共 2979 字,大约阅读时间需要 9 分钟。

--用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset--查询示例select * from openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)--导入示例select * into 表 from openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)--创建链接服务器exec sp_addlinkedserver  'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'go--查询示例select * from srv_lnk.数据库名.dbo.表名--导入示例select * into 表 from srv_lnk.数据库名.dbo.表名--以后不再使用时删除链接服务器exec sp_dropserver 'srv_lnk','droplogins'go--下面的示例访问来自某个表的数据,该表在 SQL Server 的另一个实例中。SELECT *FROM OPENDATASOURCE('SQLOLEDB','Data Source=ServerName;User ID=MyUID;Password=MyPass').Northwind.dbo.Categories--下面是个查询的示例,它通过用于 Jet 的 OLE DB 提供程序查询 Excel 电子表格。SELECT *FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:Financeaccount.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions
例如:SELECT *FROM OPENQUERY(Far_MDB, 'SELECT * FROM MDB_Member') 这就是从我的链接服务器当中去查询MDB_Member表的数据备注:1、关于链接服务器的详细情况请参阅联机丛书中的sp_addlinkedserver、 sp_addlinkedsrvlogin、sp_addserver、sp_dropserver、sp_serveroption、sp_linkedservers等系统级存储过程。2、关于此链接服务器的创建及其使用在不同环境下(全部内网服务器、一内网一公网服务器、全公网服务器)测试,均告通过。3、有时候在存储过程中访问链接服务器的时候可能会碰到如下的提示,必须要对ANSI warning 和ANSI nulls进行设置,这时候按照如下的方法进行设置:设置本地数据库的属性-->连接-->选上ANSI warning 和 ANSI nulls如何用sql语句进行跨库查询在机器B上的数据库database2中创建一个临时表#tmp, 内容就是机器A上的数据库database1里面的Table1。 如何用sql语句完成?(不借用dts等)SQL code --创建链接服务器exec sp_addlinkedserver  'ITSV','','SQLOLEDB','远程服务器名或ip地址'exec sp_addlinkedsrvlogin 'ITSV','false',null,'用户名','密码'--查询示例select * from ITSV.数据库名.dbo.表名--导入示例select * into 表 from ITSV.数据库名.dbo.表名--以后不再使用时删除链接服务器exec sp_dropserver 'ITSV','droplogins'--连接远程/局域网数据(openrowset/openquery/opendatasource)--1、openrowset--查询示例select * from openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)--生成本地表select * into 表 from openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)--把本地表导入远程表insert openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)select *from 本地表--更新本地表update bset b.列A=a.列Afrom openrowset('SQLOLEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名)as a inner join 本地表 bon a.column1=b.column1--openquery用法需要创建一个连接--首先创建一个连接创建链接服务器exec sp_addlinkedserver  'ITSV','','SQLOLEDB','远程服务器名或ip地址'--查询select *FROM openquery(ITSV, 'SELECT *  FROM 数据库.dbo.表名')--把本地表导入远程表insert openquery(ITSV, 'SELECT *  FROM 数据库.dbo.表名')select * from 本地表--更新本地表update bset b.列B=a.列BFROM openquery(ITSV, 'SELECT * FROM 数据库.dbo.表名') as a inner join 本地表 b on a.列A=b.列A--3、opendatasource/openrowsetSELECT   *FROM   opendatasource('SQLOLEDB', 'Data Source=ip/ServerName;User ID=登陆名password=密码' ).test.dbo.roy_ta--把本地表导入远程表insert opendatasource('SQLOLEDB', 'Data Source=ip/ServerName;User ID=登陆名password=密码').数据库.dbo.表名select * from 本地表用   链接服务器 OPENROWSET OPENDATASOURCE 都可以链接服务器.database1.dbo.table1链接服务器.database1.dbo.table1SQL code select * into #from openrowset('sqloledb','ip';'sa';'','select * from pubs.dbo.jobs')如果只是偶尔使用   就用opendatasource/openrowset   固定的频繁使用建linked   server

 

转载于:https://www.cnblogs.com/pilink/p/6688584.html

你可能感兴趣的文章
bulk
查看>>
js document.activeElement 获得焦点的元素
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
day6-if,while,for的快速掌握
查看>>
JavaWeb学习笔记(十四)--JSP语法
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>
angularjs表达式中的HTML内容,如何不转义,直接表现为html元素
查看>>
css技巧
查看>>
Tyvj 1728 普通平衡树
查看>>
[Usaco2015 dec]Max Flow
查看>>
javascript性能优化
查看>>
多路归并排序之败者树
查看>>
java连接MySql数据库
查看>>
转:Vue keep-alive实践总结
查看>>
android studio修改新项目package名称
查看>>
深入python的set和dict
查看>>