SQLServer 链接服务器及同义词
链接服务器
1. openrowse
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
--进行查询
select * from openrowset('SQLOLEDB', 'DRIVER={SQL Server};SERVER=47.95.15.215;UID=sa;PWD=strong;Initial Catalog=Pubs', 'select * from IStrongPro_RiverManage_GDJM.dbo.ST_PPTN_R') as a
exec sp_configure 'show advanced options',0
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
Openrowse(驱动类型,连接字符串,查询表)
驱动类型有三种:
MSDASQL/SQLNCLI/SQLOLEDB
MSDASQL
MSDASQL:Microsoft OLE DB Provider for ODBC Drivers
允许在 OLEDB 和 ADO(它在内部使用 OLEDB)上构建的应用程序通过 ODBC 驱动程序访问数据源的技术。
MSDASQL 是用于连接到 ODBC(而不是数据库)的 OLEDB 访问接口。
SQLOLEDB
SQLOLEDB :Microsoft OLE DB Provider for SQL Server,可以看出来SQLOLEDB是连接到数据库sqlserver,而不是ODBC驱动
SQLNCLI
SQLNCLI10(SQLNCLI):SQL Server Native Client 10.0
SQL Server Native Client的定义:
SQL Server Native Client 是在 SQL Server 2005 中引入的用于 OLE DB 和 ODBC 的独立数据访问应用程序编程接口 (API)。SQL Server Native Client 将 SQL OLE DB 访问接口和 SQL ODBC 驱动程序组合成一个本机动态链接库 (DLL)。为了利用在 SQL Server 2005以及以上的版本的新功能,比如多个活动结果集 (MARS)、查询通知、用户定义类型 (UDT) 或新的 xml 数据类型,那些使用 ActiveX Data Objects (ADO) 的现有应用程序应当使用 SQL Server Native Client OLE DB 访问接口作为其数据访问接口。
如果不需要使用在 SQL Server 2005 及其以后的版本中引入的任何新功能,则不需要使用 SQL Server Native Client OLE DB 访问接口;您可以继续使用当前数据访问接口(通常是 SQLOLEDB)。如果要增强现有应用程序的功能,并且需要使用在 SQL Server 2005 及其以后的版本中引入的新功能,则应当使用 SQL Server Native Client OLE DB 访问接口。
注:以上 reconfigure可能会报错
可改:禁用对 recoveryinterval 高级配置选项的配置值检查(以查找无效值或非建议值)。
reconfigure WITH OVERRIDE
例如:
exec sp_configure 'show advanced options',1
reconfigure WITH OVERRIDE`
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure WITH OVERRIDE`
go
--执行语句
go
exec sp_configure 'show advanced options',0
reconfigure WITH OVERRIDE`
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure WITH OVERRIDE`
2. 建立链接服务器
2.1 命令
--建立链接服务器
exec sp_addlinkedserver 'ServerName', '', 'SQLOLEDB','47.95.15.111'
exec sp_addlinkedsrvlogin 'ServerName', 'false',null,'sa','strong'
exec sp_serveroption N'ServerName', N'rpc out', N'true'
exec sp_serveroption N'ServerName', N'rpc', N'true'
--注 ServerName 就是查询的时候用来表示服务器名的别称。
--查询
select * from ServerName.Pro_RiverManage.dbo.ST_PPTN_R
--当然此处的ServerName也可以写数字,如果是数据,必须以双引号或中括号框起来,如[47.95.15.111] "47.95.15.111"
--Example: select * from [47.95.15.111]].Pro_RiverManage.dbo.ST_PPTN_R--(前提上面的ServerName写成47.95.15.111)
--删除链接服务器
exec sp_dropserver 'ServerName ', 'droplogins '--可以不用删除,也可以保留,只是点存储空间,影响不大,
2.2.手动界面操作
添加成功后,可以在“服务器对像》链接服务器”,可以看到刚刚添加的链接服务器,点击进行测试是否可以连接成功!
--查询的时候就可以
select * from [47.96.12.111,1433].Pro_RiverManage.dbo.ST_PPTN_R
同义词
同义词分为同库的表同义词跟跨库、跨服的同义词
这里主要说一下跨服的同义语,跨服的功能需要立足于 链接服务器
才可以使用
比如这个表单太长,我们想在本地库直接
select * from [47.96.12.111,1433].Pro_RiverManage.dbo.ST_PPTN_R
这样子,看起来这个表就跟本地的表一样,其实这个表是个远程库的表!
select * from dbo.ST_PPTN_R
实现方式就是同义词,在本地数据库映射个别名直接调用。看起来像使用本库的表一样。
1.、界面工具方式创建
确认之后就可以试写用 select * from dbo.ST_PPTN_R
像查询本地表一样进行查询,链接交给数据库链接服务器功能块去处理
2、 脚本命令方式创建
--创建同义词
create synonym dbo.ST_PPTN_R for ITSV.Pro_RiverManage.dbo.ST_PPTN_R
--查询有哪些同义词
SELECT * FROM sys.synonyms WHERE name='ST_PPTN_R'
SQLServer 链接服务器及同义词的更多相关文章
- Sqlserver 链接服务器和同义词
在数据库的日常维护中,经常会遇到跨服务器的数据传输. 例如A服务器上的数据每天要从B服务器上去获取数据,然后插入到自己的服务器上.这种情况就要用到链接服务器了. 接下来,我就把我本机当作服务器A,17 ...
- SQLSERVER 链接服务器执行存储过程
1.创建链接服务器 exec sp_addlinkedserver 'server_tmp','','SQLOLEDB','192.168.1.1' -- server_tmp 为别名 exec sp ...
- SQLSERVER 链接服务器
1. 执行代码 EXEC sp_addlinkedserver @server='XLZFSqlServer', --链接服务器别名 @srvproduct='', @provider='SQLOLE ...
- Sqlserver通过链接服务器访问Oracle的那些事儿
前言: 1.不经历风雨,怎能见彩虹. 2.充分利用BaiDu.google等搜索引擎查找资料并整合分析! 3.世上无难事只怕有心人! 本文由来:笔者在研究SQLSERVER链接服务器到oracle并使 ...
- 【转】Sqlserver通过链接服务器访问Oracle的那些事儿!
原文:http://blog.sina.com.cn/s/blog_614b6f210100t80r.html 前言:1.不经历风雨,怎能见彩虹.2.充分利用BaiDu.google等搜索引擎查找资料 ...
- Sqlserver通过链接服务器访问Oracle的解决办法
转自http://blog.sina.com.cn/s/blog_614b6f210100t80r.html 一.创建sqlserver链接服务(sqlserver链接oracle) 首先sqlse ...
- Sqlserver通过链接服务器访问Oracle
工作中遇到的情况,win 7 64位操作系统的就安装64位的oracle 客户端,然后重启sql service服务后再创建sql 链接服务器.关于如何创建链接服务器请查看下面的大神的链接: http ...
- [转]SQLSERVER存储过程调用不同数据库的数据_存储过程中通过链接服务器访问远程服务器
本文转自:http://blog.csdn.net/nnaabbcc/article/details/7967761 存储过程调用不同数据库的数据 在存储过程调用不同数据库的数据该如何做,比如在存储过 ...
- 【转】Sqlserver通过链接服务器访问Oracle的解决办法
一.创建sqlserver链接服务(sqlserver链接oracle) 首先sqlserver 链接oracle可以通过两个访问接口: “MSDAORA” 和“OraOLEDB.Oracle” 1 ...
随机推荐
- 阿里云服务器 Ubuntu 安装 LNMP
1.设定实例化服务器IP密码. 2.设定安全组件端口 80 和 3306 系统默认提供端口 22. //阿里云需要设定安全组件端口必须设定. 3.安装一键lnmp系统. 教程地址 https://ln ...
- 2018 CCPC 吉林站 H Lovers || HDU 6562 (线段树哦)
http://acm.hdu.edu.cn/showproblem.php?pid=6562 题意: q次操作 1.将第l~r个数的左边和和右边都加上一个数d, 使得这个数变成 dsiddsid的形式 ...
- ANTLR4加载csv数据
实现功能: 编写一个自定义的监听器,将逗号分隔符文件(csv)中的数据加载到一种数据结构--“由Map组成的List”中. antlr4文件: grammar CSV; file : hdr row+ ...
- Linux远程登录工具XShell安装
Xshell就是一个远程控制RHEL的软件:其他的还有很多,用什么都无所谓(根据公司情况). 下面我们来安装下这个工具: 双击exe 点下一步: 选 免费的 然后下一步:(免费的功能足够用了) 点接受 ...
- 利用 Skywalking 搭建 APM(应用性能管理)— 安装与配置
1.什么是 Skywalking Skywalking 是一个APM系统,即应用性能监控系统,为微服务架构和云原生架构系统设计.它通过探针自动收集所需的指标,并进行分布式追踪.通过这些调用链路以及指标 ...
- 125、TensorFlow计算图的执行
# TensorFlow使用tf.Session类来表示客户端程序之间的链接 # 虽然一个在其他语言中相似的接口也是可以使用的,列如C++ runtime # 一个tf.Session对象提供了访问本 ...
- 舔狗【2019河北省大学生程序设计竞赛 J题】
题目描述 > “舔狗舔狗,> 舔到最后,> 一无所有.” 有 n 只舔狗,每只舔狗的心中都有自己朝思暮想的一位. 每个人虽然受到了一万次拒绝,还毅然第一万零一次鼓起勇气. 作为一个不 ...
- 如何在Python中使用Linux epoll
如何在Python中使用Linux epoll 内容 介绍 阻塞套接字编程示例 异步套接字和Linux epoll的好处 epoll的异步套接字编程示例 性能考量 源代码 介绍 从2.6版开始,Pyt ...
- [ARC083]Collecting Balls
Description 有一个 \(n\times n\) 的矩阵,矩阵内有 \(2n\) 个球.对于 \(i \in [1,n]\) ,\((0,i) (i,0)\) 的位置各有一个启动后往右走/往 ...
- Pandas的高级操作
pandas数据处理 1. 删除重复元素 使用duplicated()函数检测重复的行,返回元素为布尔类型的Series对象,每个元素对应一行,如果该行不是第一次出现,则元素为True keep参数: ...