SQL2008和SQL2000可以跨服务器连接查询的测试实例
测试目的: SQL2008 和 SQL2000 是否可以跨服务器连接查询
-- 测试环境:
--A 虚拟机 XP ( IP : .0.0.213 )安装 SQL2000 个人版,并安装 SP4 补丁。
--Microsoft SQL Server 2000 - 8.00.2039 (Intel X86)
-- May 3 2005 23:18:38
--Copyright (c) 1988-2003 Microsoft Corporation
--Personal Edition on Windows NT 5.1 (Build 2600: Service Pack 3)
--B 虚拟机 windows2008 ( IP : .0.0.211 )安装 SQL2008 。
--Microsoft SQL Server 2008 (RTM) - 10.0.1600.22 (Intel X86)
-- Jul 9 2008 14:43:34
-- Copyright (c) 1988-2008 Microsoft Corporation
-- Enterprise Edition on Windows NT 6.0 <X86> (Build 6001: Service Pack 1)
--B 虚拟机 windows2008 ( IP : .0.0.211 )安装 SQL2000 企业版,命名实例。
--Microsoft SQL Server 2000 - 8.00.194 (Intel X86)
--Aug 6 2000 00:57:48
--Copyright (c) 1988-2000 Microsoft Corporation
--Enterprise Edition on Windows NT 6.0 (Build 6001: Service Pack 1)
-- 测试步骤:
-- (从 SQL2008 到 SQL2000 )
--=====================================================================
---- 在 B 机器( OS 2008 )上建立跨服务器连接
sp_addlinkedserver '10.0.0.213' , 'SQL Server'
-- 在 B 机器( OS 2008 )上查询连接
select server_id , name from sys . servers where right( name , 3)= '213'
--result:
server_id name
----------- ------------------------
7 10.0.0.213
( 1 行受影响 )
-- 在 B 机器( OS 2008 )上连接查询 ( 用 SA 登录,不能用 windows 身份验证 )
select top 1 OrderID , CustomerID , EmployeeID , OrderDate from [10.0.0.213] .Northwind . dbo . Orders
--result:
OrderID CustomerID EmployeeID OrderDate
----------- ---------- ----------- -----------------------
10248 VINET 5 1996- 07- 04 00: 00: 00.000
( 1 行受影响 )
--( 用 windows 身份验证登录查询会报如下错误 )
消息 18452 ,级别 14 ,状态 1 ,第 0 行
用户 '(null)' 登录失败 。原因 : 未与信任 SQL Server 连接相关联 。
-- (从 SQL2000 到 SQL2008 )
--=====================================================================
-- 在 A 机器( OS XP )上建立跨服务器连接
sp_addlinkedserver '10.0.0.211' , 'SQL Server'
(所影响的行数为 1 行 )
(所影响的行数为 1 行 )
-- 在 A 机器( OS XP )上查询连接
select * from sysservers
1249 10.0.0.211 SQL Server
-- 在 A 机器( OS XP )上连接查询 ( 用 SA 登录,不能用 windows 身份验证 )
select top 1 * from [10.0.0.211] . AdventureWorks2008 . dbo . AWBuildVersion
--result:
1 10.00.80404.00 2008- 04- 04 00: 00: 00.000 2008- 04- 04 00: 00: 00.000
--( 用 windows 身份验证登录查询会报如下错误 )
服务器 : 消息 7411 ,级别 16 ,状态 1 ,行 1
服务器 '10.0.0.211' 没有为 DATA ACCESS 的目的而配置 。
-- (从 SQL2000 个人版到 SQL2000 企业版命名实例)
--=====================================================================
-- 在 A 机器( OS XP )上建立跨服务器连接
sp_addlinkedserver '10.0.0.211/SQL2k' , 'SQL Server'
(所影响的行数为 1 行 )
(所影响的行数为 1 行 )
-- 在 A 机器( OS XP )上查询连接
select * from sysservers
1249 10.0.0.211 SQL Server
1249 10.0.0.211/SQL2k SQL Server -- 新增命名实例
-- 在 A 机器( OS XP )上连接查询
select top 1 * from [10.0.0.211/SQL2k] . Northwind . dbo . Orders
--result :
服务器 : 消息 17 ,级别 16 ,状态 1 ,行 1
SQL Server 不存在或拒绝访问 。
-- 原因为 B 虚拟机 windows2008 ( IP : .0.0.211 )安装 SQL2000 企业版,未安装 SP4 补丁。
-- 下载 SQL2000SP4
http: // download . microsoft . com / download / 9/ b / f / 9bff6646 - 2cdb - 4069- ada0 -548be9cb9338 / SQL2000 - KB884525 - SP4 - x86 - CHS . EXE
在 Windows2008 中安装 SQL2K SP4 补丁提示程序与系统不兼容 。
-- (从 SQL2000 企业版命名实例到 SQL2000 个人版)
--=====================================================================
-- 在 B 机器( OS 2008 )上建立跨服务器连接
sp_addlinkedserver '10.0.0.213' , 'SQL Server'
(所影响的行数为 1 行 )
(所影响的行数为 1 行 )
-- 在 B 机器( OS 2008 )上查询连接
select * from sysservers
1249 10.0.0.213 SQL Server
-- 用 windows 身份验证登录查询(提示错误如下)
select top 1 * from [10.0.0.213] . Northwind . dbo . Orders
服务器 : 消息 18452 ,级别 14 ,状态 1 ,行 1
用户 '(null)' 登录失败 。原因 : 未与信任 SQL Server 连接相关联 。
-- 用 sa 身份验证登录查询(但 SA 密码不相同时提示错误如下)
select top 1 * from [10.0.0.213] . Northwind . dbo . Orders
服务器 : 消息 18456 ,级别 14 ,状态 1 ,行 1
用户 'sa' 登录失败 。
--> 此时修改 B 虚拟机中的 SQL2000 企业版的 SA 密码与 A 虚拟机中 SQL2000 的 SA 密码一致。
-- 用 sa 身份验证登录查询,结果显示正常。
select top 1 * from [10.0.0.213] . Northwind . dbo . Orders
--result :
10248 VINET 5 1996- 07- 04 00: 00: 00.000 1996- 08- 01 00: 00: 00.000 1996- 07-16 00: 00: 00.000 3 32.3800 Vins et alcools Chevalier 59 rue de l 'Abbaye Reims NULL 51100 France'
总结 : SQL2008 和 SQL2000 可以跨服务器进行连接查询。 所有数据库的远程连接 dbo 的方式必须建立在 SA 密码相同的基础上 ,否则容易产生无法连接的情况 。
以上文档用实例测试了 windows2008 系统中 SQL2008 企业版和 XP 系统中 SQL2000 的跨服务器连接查询 。
关于 SQL2005 的跨服务器远程连接查询 ,详见 http: // blog . csdn . net / claro / archive / 2009/ 07/03/ 4317900.aspx
转自:http://blog.csdn.net/claro/article/details/5710808
SQL2008和SQL2000可以跨服务器连接查询的测试实例的更多相关文章
- 问题:sqlserver 跨服务器连接;结果:Sql Server 跨服务器连接
Sql Server 跨服务器连接 用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset ...
- Sql Server 跨服务器连接
用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB', 'sql服 ...
- T-SQL——关于跨库连接查询
目录 0. 同一台服务器不同数据库 1. 使用跨库查询函数--OpenDataSource() 2. 使用链接服务器(Linking Server) 3. 使用OpenDataSource()函数和链 ...
- oracle跨库连接查询
一.授权(本地客户器端授权当前用户) grant create database link to szfile 第一种连接方法:配置本地数据库服务器的tnsnames.ora文件 SZFILE = ( ...
- MSSQLSERVER跨服务器连接(远程登录)的示例代码
MSSQLSERVER跨服务器链接服务器创建方法如下 复制代码 代码如下: --声明变量 Declare @svrname varchar(255), @dbname varchar(255), @s ...
- 010.简单查询、分组统计查询、多表连接查询(sql实例)
-------------------------------------day3------------ --添加多行数据:------INSERT [INTO] 表名 [(列的列表)] --SEL ...
- SQL多表连接查询(详细实例)
转载博客:joeleo博客(http://www.xker.com/page/e2012/0708/117368.html) 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:stud ...
- SQL多表连接查询(详细实例)(转)
http://www.xker.com/page/e2012/0708/117368.html select * from student,course where student.ID=course ...
- SQL多表连接查询(具体实例)
本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student 截图例如以下: 表2:course 截图例如以下: (此时这样建表仅仅是为了演示连接SQL语句.当然实际开发中我们 ...
随机推荐
- SQLite Helper (C#) z
http://www.codeproject.com/Articles/746191/SQLite-Helper-Csharp Introduction I have written a small ...
- 【原创】Mvc学习笔记(1)
1.新建MVC4项目 在MVC4中有App_Data文件夹,这个文件夹里可以放一些重要的数据,比如说数据库的mdf文件等等,这个文件夹非常安全,因为这个文件夹不允许被别人下载,不允许被浏览器访问. A ...
- 安装plsql
sqlplus能登录,服务器.网络.tns配置应该都是好的,应该就是plsql本身的问题 问下安装路径在哪? 注意安装路径中不能有括号,不要安装在C:\Program Files (x86)目录下面
- 集合工具类 - CollectionUtil.java
集合工具类,提供数组转LIST.数组转SET.合并集合.计算笛卡儿积等方法. 源码如下:(点击下载 - CollectionUtil.java.ArrayUtil.java.commons-lang ...
- 安卓开发中,什么样的功能适合抽取成 Library?
我们都知道如果将所有的功能都写成 Library,那么我们在编写应用程序的时候就可以快速便捷的写出想要的功能,因为这些已经事先都实现过了,这样在写代码的时候就可以迅速的将 Library 依赖到我们的 ...
- mysql注入攻击及防范
一.注入攻击种类 1. GET注入 输入参数通过URL发送. 2. POST注入 输入参数通过HTTP正文发送 3. COOKIE注入 ...
- [wikioi]过河卒
棋盘型动态规划.(PPT:http://wenku.baidu.com/view/56badad850e2524de5187ea3.html)该类动态规划有一个共性,那就是在一个矩阵中(一般是二维矩阵 ...
- 织梦内容管理系统(DedeCms) 小说模块insert注入漏洞
漏洞版本: Dedecms 漏洞描述: DedeCms是免费的PHP网站内容管理系统. 织梦内容管理系统(DedeCms) 以简单.实用.开源而闻名,是国内最知名的PHP开源网站管理系统,也是使用用户 ...
- Linux内存调试工具初探-MEMWATCH
C 语言作为 Linux 系统上标准的编程语言给予了我们对动态内存分配很大的控制权.这种自由可能会导致严重的内存管理问题,可能导致程序崩溃或随时间的推移导致性能降级. 内存泄漏(即 malloc() ...
- (转载)按行合并两个sql的查询结果
(转载)http://blog.csdn.net/wxwstrue/article/details/6784774 Union all join 是平行合并 为水平连接 Union all 是垂直合并 ...