日期:2014-05-18  浏览次数:20626 次

简单的SQL查询语句
请问在本地查询远程的服务器数据库中的数据怎么写SQL语句,例如远程服务器的IP是:192.168.1.40   要查询pubs数据库中的test表

用SQL语句怎么打开远程数据库然后
select   *   from   pubs.dbo.test
先谢谢啦!

------解决方案--------------------
USE pubs
GO
SELECT a.*
FROM OPENROWSET( 'SQLOLEDB ', 'seattle1 '; 'sa '; 'MyPass ',
'SELECT * FROM pubs.dbo.authors ORDER BY au_lname, au_fname ') AS a
GO


------解决方案--------------------
--创建链接服务器
exec sp_addlinkedserver 'srv_lnk ', ' ', 'SQLOLEDB ', '远程服务器名或ip地址 '
exec sp_addlinkedsrvlogin 'srv_lnk ', 'false ',null, '用户名 ', '密码 '
go

--查询示例
select * from srv_lnk.数据库名.dbo.表名

--以后不再使用时删除链接服务器
exec sp_dropserver 'srv_lnk ', 'droplogins '
go

--如果只是临时访问,可以直接用openrowset
--查询示例
select * from openrowset( 'SQLOLEDB '
, 'sql服务器名 '; '用户名 '; '密码 '
,数据库名.dbo.表名)
------解决方案--------------------
EXEC sp_addlinkedserver 'OracleSvr ',
'Oracle 7.3 ',
'MSDAORA ',
'ORCLDB '
GO
SELECT *
FROM OPENQUERY(OracleSvr, 'SELECT name, id FROM joe.titles ')
GO


------解决方案--------------------
SELECT *
FROM OPENDATASOURCE(
'SQLOLEDB ',
'Data Source=ServerName;User ID=MyUID;Password=MyPass '
).Northwind.dbo.Categories