• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

SQLServer跨库查询

mysql 搞代码 4年前 (2022-01-09) 23次浏览 已收录 0个评论

用openrowset连接远程SQL或插入数据 –如果只是临时访问,可以直接用openrowset — 查询 示例 select*fromopenrowset(‘SQLOLEDB’ ,’sql服务器名’;’用户名’;’密码’ ,数据库名.dbo.表名) –导入示例 select*into表fromopenrowset(‘SQLOLEDB’ ,’sql服务器名’;’用

用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 b

set b.列A=a.列A

from openrowset(‘SQLOLEDB’,’sql服务器名’;’用户名’;’密码’,数据库名.dbo.表名)as a inner join 本地表 b

on 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 b

set b.列B=a.列B

FROM open本文来源gao@daima#com搞(%代@#码网@query(ITSV, ‘SELECT * FROM 数据库.dbo.表名’) as a

inner join 本地表 b on a.列A=b.列A

–3、opendatasource/openrowset

SELECT *

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.table1

SQL code

select * into #

from openrowset(‘sqloledb’,’ip’;’sa’;”,’select * from pubs.dbo.jobs’)

如果只是偶尔使用 就用opendatasource/openrowset 固定的频繁使用建linked server


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:SQLServer跨库查询

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址