SELECT *FROM OPENDATASOURCE('SQLOLEDB','Data Source=sql服务器名;User ID=用户名;Password=密码;').PersonDb.dbo.Table_1sql
exec sp_dropserver 'SQL2','droplogins'数据库
exec sp_addlinkedserver @server= 'SQL2', @srvproduct= '',
@provider='SQLNCLI', @datasrc = 'sql服务器名' --登陆连接服务器
exec sp_addlinkedsrvlogin @rmtsrvname = 'SQL2',
@useself = 'false ', @locallogin = null,
@rmtuser ='用户名', @rmtpassword = '密码'服务器
select * from SQL2.PersonDb.dbo.Table_1ide
-------------------------------------------------------------------------------------------------------测试
用openrowset链接远程SQL或插入数据spa
--若是只是临时访问,能够直接用openrowsetcode
--查询示例server
select * from openrowset('SQLOLEDB'ip
,'sql服务器名';'用户名';'密码'io
,数据库名.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表的数据
备注:
一、关于连接服务器的详细状况请参阅联机丛书中的sp_addlinkedserver、 sp_addlinkedsrvlogin、sp_addserver、sp_dropserver、sp_serveroption、sp_linkedservers等系统级存储过程。
二、关于此连接服务器的建立及其使用在不一样环境下(所有内网服务器、一内网一公网服务器、全公网服务器)测试,均告经过。
三、有时候在存储过程当中访问连接服务器的时候可能会碰到以下的提示,必需要对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)
--一、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 openquery(ITSV, 'SELECT * FROM 数据库.dbo.表名') as a
inner join 本地表 b on a.列A=b.列A
--三、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