一 测试环境 操作系统 Red Hat As 2.1 数据库 SQLServer2000 installed in windows xp professional,我假定数据库有用户autotest 密码是autotest,数据库文件是atsdb 注意: 1 MS从来没有提供过SQLServer for Linux,所以大家也不要去尝试在Linux系统安装SQLServer,但是可以通过ODBC连接Windows系统的SQLServer数据库; 2 安装的SQLServer2000是不会打开1433端口的,所以请Windows xp 用户在安装完SQLServer之后一定装上SQLServer SP3布丁,可以使用命令netstat -a 来查看是否打开1433端口 3 对于windows xp,缺省防火墙是不让1433端口来通讯的,所以必须关掉windows的防火墙,这个问题折腾我一天,老是连接不成功,我还以为是odbc软件的配置问题,教训呀。最可气的是在别的windows机器使用sqlserver的命令isql能够访问数据库,(不用关闭防火墙)。通过抓包工具发现根本就不通过1433端口通讯,而是通过445或139内部端口通讯呀,真要命呀,看来windowns东西是好,但是也太霸道了呀 4 在xp sp2安装sqlserver2000时必须要打chs_sql2ksp3.exe补丁,如果没有这个补丁,telnet ip 1433会连接不了,当然从远程客户端连接不上,就这个问题折腾一个下午,晕呀 Linux系统的ODBC unixODBC-2.2.8.tar.gz ( http://www.unixodbc.org) 连接SQLServer或Sybase的驱动 freetds-0.62.4.tar.gz ( http://www.freetds.org) 二 安装配置(必须在root下用户安装) 1、安装unixODBC # tar vxzf unixODBC-2.2.8.tar.gz 2、安装freetds # tar vxzf freetds-0.62.4.tar.gz # cd /usr/local/freetds 修改以下的一段,并把;去掉 [SQLServer2000] 测试连接: $ tsql -S SQLServer2000 -U autotest -P autotest 这说明安装freetds成功 4、配置unixODBC # cd /usr/local/unixODBC 向ODBC添加SQLServer驱动 # vi etc/odbcinst.ini [ODBC] # vi etc/odbc.ini 写入如下内容
保存并退出。 测试ODBC的连接 # bin/isql -v ATSDB autotest autotest 下面就可以使用freetds的api开发连接sqlserver2000数据库的程序了,可以使用c、c++编写 |
在Red hat Linux下通过ODBC连接SQLServer2000
最新推荐文章于 2023-02-05 20:12:04 发布
一 测试环境