SQL2000和SQL2005冲突的解决方法

SQL2000和SQL2005冲突的解决方法

1、因为SQL2000安装过程中无法修改实例名称,故安装过程中必须先安装SQL2000,然后再安装SQL2005。安装SQL2005时必须修改SQL实例名称,否则将和SQL2000的实例名称冲突。

2、安装完SQL2005后,开始准备用SQL2000客户端工具连接SQL2005,结果报告不能用SQL2000客户端工具连接,只能用SQL2005客户端工具连接,后证明SQL2005客户端工具可以同时连接SQL2000和SQL2005。

3、服务器上安装完成后,准备用远程连接SQL服务器试试,结果始终连接不上SQL2005,只能连接上SQL2000。原来SQL2000服务器用的端口始终是1433端口,而SQL2005使用的是动态端口。那如果用程序连接SQL20005服务器的时候,程序如何知道SQL2005服务器用的是什么端口呢?原来SQL2005提供了一个SQL BROWER服务,开启这个服务后,就可以通过查询SQL BROWER服务知道SQL2005现在正在使用哪个端口了。因为项目需要把这个SQL2005的动态端口改成静态的,修改过程如下:

运行SQL配置管理程序,找到SQL实例名称下面的协议,双击右边的TCP/IP协议,在第二选项卡中IPALL里面输入SQL运行的端口就可以了(注意不能同时填写动态端口和静态端口,否则SQL下次将无法启动),修改完成后重新启动SQL服务即可生效。

4、修改端口后在连接发现仍然不能连接,原来还需要开启SQL2005的远程登陆服务。

在Microsoft SQL Server 2005中默认是不允许远程登录的,会出现“provider: SQL 网络接口, error: 26 - 定位指定的服务器/实例时出错”的错误,下面的方法可以打开:

配置工具->sql server外围应用配置器->服务和连接的外围应用配置器->打开MSSQLSERVER节点下的Database Engine节点,先择“远程连接”,接下来建议选择“同时使用TCP/IP和named pipes”,确定后,重启数据库服务就可以。

5、远程登陆服务和端口都修改之后连接应该没有问题了吧。结果远程连接SQL2000的时候发现没有问题,但是连接SQL20005依然不行,在SQL2005的客户端连接工具里需要输入您要连接的SQL服务,SQL2000直接输入服务器的IP地址即可,那如何输入才能让客户端工具连接到SQL2005的服务呢?既然SQL2005修改了端口,那按照常规的录入格式输入“IP地址+冒号+端口号”应该就可以了,结果试了一下发现依然不行。后来又修改了客户端连接的默认端口,结果仍然不行。没办法了,只有到网上Google了一翻,结果终于在一篇英文文章中找到了连接的方法,原来按照常规的格式录入是错误的,需要改成“IP地址+逗号+端口号”才行。