我现在要使用两台电脑,在同一个局域网里,互相访问对方的数据库,版本是SQL2000的。可以通过“新建注册”的方式,访问对方的数据库的表。
现在我想在c#程序里面自动访问,总是超时。
我在网上搜了下这个现象和解决的方法,如下:
************************
配置sql server 2000以允许远程访问
适合故障:
1. 用sql企业管理器能访问sql server 2000(因为它是采用命名管道(named pipes)方式进行方式),但用ado.net 方式(udp)不能访问.
2. 采用ado.net方式不能远程访问.
故障的可能原因有:
1.sql server 2000没有安装sql server 2000 sp3a及以上升级包,还未启用并开放1433端口(udp);
2.系统防火墙未开放1433端口.解决办法:
一.检查sql server 2000是否已启用并开放1433端口.(在sql2000服务器上)
   方法:
   开始-->运行-->打开-->执行 "cmd" 命令 -->执行 "netstat -na" 命令.
   看是否有无
   TCP         127.0.0.1:1433               0.0.0.0:0                             LISTENING   
   TCP         192.168.123.98:1433          0.0.0.0:0                             LISTENING
如果没有刚表明sql2000端口监听服务未启动. 
转第三步.
如果有则转第二步二.检查sql server 2000服务器所在机器防火墙设置,sql server 2000服务器端是否启动Sql Server服务.
   主要检查防火墙是否设置允许1433端口通信. 简单的方法是关闭防火墙后再试.
   方法:
    在客户端或本机"命令提示符"窗口运行下面命令 : telnet <sql2000服务器IP地址> 1433
    如果命令执行成功,说明 SQL Server 服务器工作正常,并且正在监听1433端口的 TCP/IP 连接
    如果命令返回"无法打开连接"的错误信息,则说明服务器端没有启动 SQL Server 服务,
    也可能服务器端没启用 TCP/IP 协议,或者服务器端没有在 SQL Server 默认的端口1433上监听.
    是否启动 SQL Server 服务或监听端口通过sql2000网络配置工具来检查.三.检查sql server 2000是否已升级到8.00.760或以上版本.
   方法:
   在sql查询分析器中执行:
   SELECT SERVERPROPERTY('ProductLevel')
   SELECT @@VERSION 
   SELECT SERVERPROPERTY('ProductVersion')    如果为8.00.760以下则需安装sql2000 sp3a或sql2000 sp4
*****************************开始-->运行-->打开-->执行 "cmd" 命令 -->执行 "netstat -na" 命令.
   我的只有   TCP         127.0.0.1:1433               0.0.0.0:0                             LISTENING   
  ***没有这个: TCP         192.168.155.231:1433          0.0.0.0:0                             LISTENING*****
按照上面的说法,只要装SP4的补丁就可以,我安装了补丁,还是看不到 
TCP         192.168.155.231:1433          0.0.0.0:0                             LISTENING
******************************
请教高手,我还需要做哪些修改和配置才能访问对方的数据库呢?
谢谢

解决方案 »

  1.   

    远程连接sql server 2000服务器的解决方案  一 看ping 服务器IP能否ping通。   这个实际上是看和远程sql server 2000服务器的物理连接是否存在。如果不行,请检查网络,查看配置,当然得确保远程sql server 2000服务器的IP拼写正确。   二 在Dos或命令行下输入telnet 服务器IP 端口,看能否连通。   如telnet 202.114.100.100 1433   通常端口值是1433,因为1433是sql server 2000的对于Tcp/IP的默认侦听端口。如果有问题,通常这一步会出问题。通常的提示是“……无法打开连接,连接失败"。   如果这一步有问题,应该检查以下选项。   1 检查远程服务器是否启动了sql server 2000服务。如果没有,则启动。   2 检查服务器端有没启用Tcp/IP协议,因为远程连接(通过因特网)需要靠这个协议。检查方法是,在服务器上打开 开始菜单-> 程序-> Microsoft SQL Server-> 服务器网络实用工具,看启用的协议里是否有tcp/ip协议,如果没有,则启用它。   3 检查服务器的tcp/ip端口是否配置为1433端口。仍然在服务器网络实用工具里查看启用协议里面的tcp/ip的属性,确保默认端口为1433,并且隐藏服务器复选框没有勾上。   事实上,如果默认端口被修改,也是可以的,但是在客户端做telnet测试时,写服务器端口号时必须与服务器配置的端口号保持一致。如果隐藏服务器复选框被勾选,则意味着客户端无法通过枚举服务器来看到这台服务器,起到了保护的作用,但不影响连接,但是Tcp/ip协议的默认端口将被隐式修改为2433,在客户端连接时必须作相应的改变。   4 如果服务器端操作系统打过sp2补丁,则要对windows防火墙作一定的配置,要对它开放1433端口,通常在测试时可以直接关掉windows防火墙(其他的防火墙也关掉最好)。   5 检查服务器是否在1433端口侦听。如果服务器没有在tcp连接的1433端口侦听,则是连接不上的。检查方法是在服务器的dos或命令行下面输入   netstat -a -n 或者是netstat -an,在结果列表里看是否有类似 tcp 127.0.0.1 1433 listening 的项。如果没有,则通常需要给sql server 2000打上至少sp3的补丁。其实在服务器端启动查询分析器,输入 select @@version 执行后可以看到版本号,版本号在8.0.2039以下的都需要打补丁。   如果以上都没问题,这时你再做telnet 服务器ip 1433 测试,将会看到屏幕一闪之后光标在左上角不停闪动。恭喜你,你马上可以开始在企业管理器或查询分析器连接了。   三 检查客户端设置   程序-> Microsoft SQL Server -> 客户端网络使用工具。像在服务器网络实用工具里一样,确保客户端tcp/ip协议启用,并且默认端口为1433(或其他端口,与服务器端保持一致就行)。   四 在企业管理器里或查询那分析器连接测试   企业管理器-> 右键SQlserver组-> 新建sqlserver注册-> 下一步-> 写入远程IP-> 下一步-> 选Sqlserver登陆-> 下一步-> 写入登陆名与密码(sa,password)-> 下一步-> 下一步-> 完成   查询分析器-> 文件-> 连接-> 写入远程IP-> 写入登录名和密码(sa,password)-> 确定   通常建议在查询分析器里做,因为默认情况下,通过企业管理器注册另外一台SQL Server的超时设置是4秒,而查询分析器是15秒。   修改默认连接超时的方法:   企业管理器-> 工具-> 选项-> 在弹出的"SQL Server企业管理器属性"窗口中,点击"高级"选项卡-> 连接设置-> 在 登录超时(秒) 后面的框里输入一个较大的数字   查询分析器-> 工具-> 选项-> 连接-> 在 登录超时(秒) 后面的框里输入一个较大的数字   通常就可以连通了,如果提示错误,则进入下一步。   五 错误产生的原因通常是由于SQL Server使用了"仅 Windows"的身份验证方式,因此用户无法使用SQL Server的登录帐户(如 sa )进行连接。解决方法如下所示:   1 在服务器端使用企业管理器,并且选择"使用 Windows 身份验证"连接上 SQL Server。   2 展开"SQL Server组",鼠标右键点击SQL Server服务器的名称,选择"属性",再选择"安全性"选项卡。   3 在"身份验证"下,选择"SQL Server和 Windows "。   4 重新启动SQL Server服务。(在dos或命令行下面net stop mssqlserver停止服务,net start mssqlserver启动服务,也是一种快捷的方法)。 
      

  2.   

    --sql server 2000
    如何打开1433端口?本地连接--〉属性--〉TCP/IP属性--〉高级--〉选项--〉TCP/IP 筛选属性然后自己添加就可以了。--sql server 2005
    如何打开sql server 2005 的1433端口配置工具-->Sql Server Configuration Manager-->MSSQLSERVER的协议看看TCP/IP协议是否启动,如果启动,右键菜单点"属性" ,在分页菜单中选"IP地址",把"IP1"和"IP2"中"TCP端口"为1433,"已启用"改为"是"配置工具-->Sql Server Configuration Manager-->SQL Native Client 配置-->客户端协议-->TCP/IP选择TCP/IP右键菜单中"属性",确认"默认端口"是1433,"已启用"为"是"
      

  3.   

      1 检查远程服务器是否启动了sql server 2000服务。如果没有,则启动。  2 检查服务器端有没启用Tcp/IP协议,因为远程连接(通过因特网)需要靠这个协议。检查方法是,在服务器上打开开始菜单-> 程序-> Microsoft SQL Server-> 服务器网络实用工具,看启用的协议里是否有tcp/ip协议,如果没有,则启用它。  3 检查服务器的tcp/ip端口是否配置为1433端口。仍然在服务器网络实用工具里查看启用协议里面的tcp/ip的属性,确保默认端口为1433,并且隐藏服务器复选框没有勾上。
      

  4.   

    如何打开1433端口?本地连接--〉属性--〉TCP/IP属性--〉高级--〉选项--〉TCP/IP 筛选属性然后自己添加就可以了。
    *************
    我看了下,我电脑的这里设置:“TCP端口”--上面选的是“全部允许”,难道是选下面的“只允许”,然后把1433加进去?
    请 dawugui
     
    (爱新觉罗.毓华)  老大再说下,谢谢
      

  5.   

    感谢 htl258 (Tony) 老大的回答,我按你写的逐条看,每条我的设置都对,现在还是看不到我自己的1433端口打开