日期:2014-05-19  浏览次数:20477 次

OPENROWSET使用问题?
使用:
SET   QUOTED_IDENTIFIER   ON  
GO
SET   ANSI_NULLS   ON  
GO


CREATE   VIEW   erp_inall_view
AS
select   *   from   OPENROWSET( 'MSDASQL ', 'DRIVER={SQL   Server};SERVER=192.168.0.19;UID=sa;PWD= ',dia.dbo.dia_two_view)   AS     am_tab


GO
SET   QUOTED_IDENTIFIER   OFF  
GO
SET   ANSI_NULLS   ON  
GO
出现如下提示:
服务器:   消息   7399,级别   16,状态   1,过程   erp_inall_view,行   7
OLE   DB   提供程序   'MSDASQL '   报错。验证失败。
[OLE/DB   provider   returned   message:   [Microsoft][ODBC   SQL   Server   Driver][SQL   Server]Login   failed   for   user   'dia '.   Reason:   Not   associated   with   a   trusted   SQL   Server   connection.]

??



------解决方案--------------------


select * from OPENROWSET( 'MSDASQL ',--改为 'SQLOLEDB '
'DRIVER={SQLServer};SERVER=192.168.0.19;UID=sa;PWD= ',dia.dbo.dia_two_view) AS am_tab
------解决方案--------------------
改为这样试试
select * from OPENROWSET( 'SQLOLEDB ',
'192.168.0.19 '; 'sa ';PWD= ' ',dia.dbo.dia_two_view) AS am_tab
------解决方案--------------------
用其它方法试试
--创建链接服务器
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

--如果只是临时访问,可以直接用openrowset
--查询示例
select * from openrowset( 'SQLOLEDB '
, 'sql服务器名 '; '用户名 '; '密码 '
,数据库名.dbo.表名)


--导入示例
select * into 表 from openrowset( 'SQLOLEDB '
, 'sql服务器名 '; '用户名 '; '密码 '
,数据库名.dbo.表名)
select * from openrowset( 'SQLOLEDB '
, 'sql服务器名 '; '用户名 '; '密码 '
,数据库名.dbo.表名)
openrowset可以用下面两个
OPENDATASOURCE或是openquery