测试目的: 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可以跨服务器连接查询的测试实例的更多相关文章

  1. 问题:sqlserver 跨服务器连接;结果:Sql Server 跨服务器连接

    Sql Server 跨服务器连接 用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset ...

  2. Sql Server 跨服务器连接

    用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB', 'sql服 ...

  3. T-SQL——关于跨库连接查询

    目录 0. 同一台服务器不同数据库 1. 使用跨库查询函数--OpenDataSource() 2. 使用链接服务器(Linking Server) 3. 使用OpenDataSource()函数和链 ...

  4. oracle跨库连接查询

    一.授权(本地客户器端授权当前用户) grant create database link to szfile 第一种连接方法:配置本地数据库服务器的tnsnames.ora文件 SZFILE = ( ...

  5. MSSQLSERVER跨服务器连接(远程登录)的示例代码

    MSSQLSERVER跨服务器链接服务器创建方法如下 复制代码 代码如下: --声明变量 Declare @svrname varchar(255), @dbname varchar(255), @s ...

  6. 010.简单查询、分组统计查询、多表连接查询(sql实例)

    -------------------------------------day3------------ --添加多行数据:------INSERT [INTO] 表名 [(列的列表)] --SEL ...

  7. SQL多表连接查询(详细实例)

    转载博客:joeleo博客(http://www.xker.com/page/e2012/0708/117368.html) 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:stud ...

  8. SQL多表连接查询(详细实例)(转)

    http://www.xker.com/page/e2012/0708/117368.html select * from student,course where student.ID=course ...

  9. SQL多表连接查询(具体实例)

    本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student  截图例如以下: 表2:course  截图例如以下: (此时这样建表仅仅是为了演示连接SQL语句.当然实际开发中我们 ...

随机推荐

  1. android SurfaceView绘制 重新学习--基础绘制

    自从大二写了个android游戏去参加比赛,之后就一直写应用,一直没用过SurfaceView了,现在进入了游戏公司,准备从基础开始重新快速的学一下这个,然后再去研究openGL和游戏引擎. 直接上代 ...

  2. HttpWebRequest提高效率之连接数,代理,自动跳转,gzip请求等设置问题

    先设置4个: [csharp] webrequest.ServicePoint.Expect100Continue = false; //是否使用 Nagle 不使用 提高效率 webrequest. ...

  3. Listview 异步加载图片之优化篇(有图有码有解释)

    在APP应用中,listview的异步加载图片方式能够带来很好的用户体验,同时也是考量程序性能的一个重要指标.关于listview的异步加载,网上其实很多示例了,中心思想都差不多,不过很多版本或是有b ...

  4. ajax 初始化请求前携带参数

     $(function () {     function SetAjax(wxOpenId, departCode) {         $.ajaxSetup({             xhrF ...

  5. VS2013 取消 直接单击文件 然后直接打开

    工具——选项——

  6. 检查并创建目录mkdir

    os.listdir() os.path.isdir() os.path.join() os.mkdir() # -*- coding:utf-8 -*- import os,sys def mkdi ...

  7. 【HDOJ】3315 My Brute

    几乎与2853相同,MCMF. /* 2853 */ #include <iostream> #include <string> #include <map> #i ...

  8. Javascript水平提升

    1,学习js分几个阶段,没入门,入门初学者,中级水平,高级水平,ppt水平. 2,没入门的如何学习? 我当初是先学jquery,有css和html基础,有css基础看jq的语法很简单,就是选择符,jq ...

  9. FindBugs

    FindBugs是一个能静态分析源代码中可能会出现Bug的Eclipse插件工具. 可以从http://sourceforge.net/project/showfiles.php?group_id=9 ...

  10. (转载)LINUX UNBUNTU10.04 下 搭建OC编译环境

    (转载)http://blog.sina.com.cn/s/blog_833996210100rgl4.html 1安装 / install GNUstep on ubuntu 下面列出来的包是安装G ...