两台电脑之间用SQL2000进行数据库的远程登录不成功

yilaozhuang 2010-05-12 07:36:51
我现在要使用两台电脑,在同一个局域网里,互相访问对方的数据库,版本是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
******************************
请教高手,我还需要做哪些修改和配置才能访问对方的数据库呢?
谢谢
...全文
506 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
yilaozhuang 2010-05-12
  • 打赏
  • 举报
回复
28 49 30 785,论坛是不是不给发号码,还请老大不吝赐教,先谢谢
htl258_Tony 2010-05-12
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 yilaozhuang 的回复:]
引用 3 楼 htl258 的回复:
  1 检查远程服务器是否启动了sql server 2000服务。如果没有,则启动。

  2 检查服务器端有没启用Tcp/IP协议,因为远程连接(通过因特网)需要靠这个协议。检查方法是,在服务器上打开开始菜单-> 程序-> Microsoft SQL Server-> 服务器网络实用工具,看启用的协议里是否有tcp/ip协议,如果没有,则启用它。
……
[/Quote]
留个QQ看能不能解决
yilaozhuang 2010-05-12
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 htl258 的回复:]
  1 检查远程服务器是否启动了sql server 2000服务。如果没有,则启动。

  2 检查服务器端有没启用Tcp/IP协议,因为远程连接(通过因特网)需要靠这个协议。检查方法是,在服务器上打开开始菜单-> 程序-> Microsoft SQL Server-> 服务器网络实用工具,看启用的协议里是否有tcp/ip协议,如果没有,则启用它。

  3 检查服务器的tcp/ip端口……
[/Quote]
感谢 htl258 (Tony) 老大的回答,我按你写的逐条看,每条我的设置都对,现在还是看不到我自己的1433端口打开
dawugui 2010-05-12
  • 打赏
  • 举报
回复
全部允许即可.

yilaozhuang 2010-05-12
  • 打赏
  • 举报
回复
如何打开1433端口?

本地连接--〉属性--〉TCP/IP属性--〉高级--〉选项--〉TCP/IP 筛选属性

然后自己添加就可以了。
*************
我看了下,我电脑的这里设置:“TCP端口”--上面选的是“全部允许”,难道是选下面的“只允许”,然后把1433加进去?
请 dawugui

(爱新觉罗.毓华) 老大再说下,谢谢
youyou2404 2010-05-12
  • 打赏
  • 举报
回复
关防火墙
htl258_Tony 2010-05-12
  • 打赏
  • 举报
回复
  1 检查远程服务器是否启动了sql server 2000服务。如果没有,则启动。

  2 检查服务器端有没启用Tcp/IP协议,因为远程连接(通过因特网)需要靠这个协议。检查方法是,在服务器上打开开始菜单-> 程序-> Microsoft SQL Server-> 服务器网络实用工具,看启用的协议里是否有tcp/ip协议,如果没有,则启用它。

  3 检查服务器的tcp/ip端口是否配置为1433端口。仍然在服务器网络实用工具里查看启用协议里面的tcp/ip的属性,确保默认端口为1433,并且隐藏服务器复选框没有勾上。
dawugui 2010-05-12
  • 打赏
  • 举报
回复
--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,"已启用"为"是"

dawugui 2010-05-12
  • 打赏
  • 举报
回复
远程连接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启动服务,也是一种快捷的方法)。

22,301

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧