在T-SQL语句中访问远程数据库(openrowset/opendatasource/openquery)

简介: 原文:在T-SQL语句中访问远程数据库(openrowset/opendatasource/openquery)1、启用Ad Hoc Distributed Queries 在使用openrowset/opendatasource前搜先要启用Ad Hoc Distributed Queries服...
原文: 在T-SQL语句中访问远程数据库(openrowset/opendatasource/openquery)

1、启用Ad Hoc Distributed Queries

在使用openrowset/opendatasource前搜先要启用Ad Hoc Distributed Queries服务,因为这个服务不安全所以SqlServer默认是关闭的

启用Ad Hoc Distributed Queries的方法

SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource'

的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用

sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细

信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。
启用Ad Hoc Distributed Queries的方法,执行下面的查询语句就可以了:

exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
使用完毕后,记得一定要要关闭它,因为这是一个安全隐患,切记执行下面的SQL语句

exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure 

 

2、使用示例

复制代码
-- 创建链接服务器 
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   openquery (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  本地表
复制代码

 

 

3、自己写的例子

 

复制代码
-- openrowset使用OLEDB的一些例子
select   *   from   openrowset ( ' SQLOLEDB ' , ' Server=(local);PWD=***;UID=sa; ' , ' select * from TB.dbo.school ' as  t
select   *   from   openrowset ( ' SQLOLEDB ' , ' Server=(local);PWD=***;UID=sa; ' ,TB.dbo.school)  as  t
select   *   from   openrowset ( ' SQLOLEDB ' , ' Server=(local);Trusted_Connection=yes; ' ,TB.dbo.school)  as  t
select   *   from   openrowset ( ' SQLOLEDB ' , ' (local) ' ; ' sa ' ; ' *** ' , ' select * from TB.dbo.school ' as  t
select   *   from   openrowset ( ' SQLOLEDB ' , ' (local) ' ; ' sa ' ; ' *** ' ,TB.dbo.school)  as  t
select   *   from   openrowset ( ' SQLOLEDB ' , ' (local) ' ; ' sa ' ; ' *** ' , ' select school.id as id1,people.id as id2 from TB.dbo.school inner join TB.dbo.people on school.id=people.id ' as  t

-- openrowset使用SQLNCLI的一些例子(SQLNCLI在SqlServer2005以上才能使用)
select   *   from   openrowset ( ' SQLNCLI ' , ' (local) ' ; ' sa ' ; ' *** ' , ' select * from TB.dbo.school ' as  t
select   *   from   openrowset ( ' SQLNCLI ' , ' Server=(local);Trusted_Connection=yes; ' , ' select * from TB.dbo.school ' as  t
select   *   from   openrowset ( ' SQLNCLI ' , ' Server=(local);UID=sa;PWD=***; ' , ' select * from TB.dbo.school ' as  t
select   *   from   openrowset ( ' SQLNCLI ' , ' Server=(local);UID=sa;PWD=***; ' ,TB.dbo.school)  as  t
select   *   from   openrowset ( ' SQLNCLI ' , ' Server=(local);UID=sa;PWD=***;DataBase=TB ' , ' select * from dbo.school ' as  t

-- openrowset其他使用
insert   openrowset ( ' SQLNCLI ' , ' Server=(local);Trusted_Connection=yes; ' , ' select name from TB.dbo.school where id=1 ' values ( ' ghjkl ' ) /* 要不要where都一样,插入一行 */
update   openrowset ( ' SQLNCLI ' , ' Server=(local);Trusted_Connection=yes; ' , ' select name from TB.dbo.school where id=1 ' set  name = ' kkkkkk '
delete   from   openrowset ( ' SQLNCLI ' , ' Server=(local);Trusted_Connection=yes; ' , ' select name from TB.dbo.school where id=1 ' )







-- opendatasource使用SQLNCLI的一些例子
select   *   from   opendatasource ( ' SQLNCLI ' , ' Server=(local);UID=sa;PWD=***; ' ).TB.dbo.school  as  t
select   *   from   opendatasource ( ' SQLNCLI ' , ' Server=(local);UID=sa;PWD=***;DataBase=TB ' ).TB.dbo.school  as  t

-- opendatasource使用OLEDB的例子
select   *   from   opendatasource ( ' SQLOLEDB ' , ' Server=(local);Trusted_Connection=yes; ' ).TB.dbo.school  as  t

-- opendatasource其他使用
insert   opendatasource ( ' SQLNCLI ' , ' Server=(local);Trusted_Connection=yes; ' ).TB.dbo.school(name)  values ( ' ghjkl ' ) /* 要不要where都一样,插入一行 */
update   opendatasource ( ' SQLNCLI ' , ' Server=(local);Trusted_Connection=yes; ' ).TB.dbo.school  set  name = ' kkkkkk '
delete   from   opendatasource ( ' SQLNCLI ' , ' Server=(local);Trusted_Connection=yes; ' ).TB.dbo.school  where  id = 1







-- openquery使用OLEDB的一些例子
exec  sp_addlinkedserver    ' ITSV ' '' ' SQLOLEDB ' , ' (local) '  
exec  sp_addlinkedsrvlogin  ' ITSV ' ' false ' , null ' sa ' ' *** '
select   *   FROM   openquery (ITSV,   ' SELECT *  FROM TB.dbo.school  '

-- openquery使用SQLNCLI的一些例子
exec  sp_addlinkedserver    ' ITSVA ' '' ' SQLNCLI ' , ' (local) '  
exec  sp_addlinkedsrvlogin  ' ITSVA ' ' false ' , null ' sa ' ' *** '
select   *   FROM   openquery (ITSVA,   ' SELECT *  FROM TB.dbo.school  '

-- openquery其他使用
insert   openquery (ITSVA, ' select name from TB.dbo.school where id=1 ' values ( ' ghjkl ' ) /* 要不要where都一样,插入一行 */
update   openquery (ITSVA, ' select name from TB.dbo.school where id=1 ' set  name = ' kkkkkk '
delete   openquery (ITSVA, ' select name from TB.dbo.school where id=1 ' )
目录
相关文章
|
3月前
|
SQL Java 数据库连接
除了JDBC,还有哪些常见的数据库访问技术?
除了JDBC,还有哪些常见的数据库访问技术?
365 2
|
5月前
|
SQL 机器学习/深度学习 人工智能
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
本文系统性地阐述了自然语言转SQL(NL2SQL) 技术如何让非技术背景的业务分析师实现数据自助查询,从而提升数据驱动决策的效率与准确性。
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
|
4月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
918 152
|
4月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
|
4月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
483 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
3月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
246 6
|
4月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
4月前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
372 8
|
5月前
|
SQL 人工智能 Java
用 LangChain4j+Ollama 打造 Text-to-SQL AI Agent,数据库想问就问
本文介绍了如何利用AI技术简化SQL查询操作,让不懂技术的用户也能轻松从数据库中获取信息。通过本地部署PostgreSQL数据库和Ollama模型,结合Java代码,实现将自然语言问题自动转换为SQL查询,并将结果以易懂的方式呈现。整个流程简单直观,适合初学者动手实践,同时也展示了AI在数据查询中的潜力与局限。
664 8
|
5月前
|
SQL 人工智能 Linux
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
326 5