在Red hat Linux下通过ODBC连接SQLServer2000
2006-07-05 09:57
513 查看
一 测试环境操作系统 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 # cd unixODBC-2.2.8 # ./configure --prefix=/usr/local/unixODBC # make # make install2、安装freetds
# tar vxzf freetds-0.62.4.tar.gz # cd freetds-0.62.4 # ./configure --prefix=/usr/local/freetds --with-unixodbc=/usr/local/unixODBC --with-tdsver=8.0 # make # make install
3、配置freetds
# cd /usr/local/freetds# vi etc/freetds.conf
修改以下的一段,并把;去掉改好之后的内容:
[global] # TDS protocol version tds version = 8.0[SQLServer2000] host = 192.168.1.110 port = 1433 tds version = 8.0 client charset = ISO-8859-1
其中的[SQLServer2000]代表在客户端使用的服务器名称(在tsql命令中要加入 -S SQLServer2000),host代表SQLServer服务器的IP地址,port代表端口.client charset 是客户端使用的字符集,我的机器使用utf-8会报连接失败的错误,发现tsql使用ISO-8859-1字符集可以连接成功,所以这儿也改成这样
测试连接:
$ tsql -S SQLServer2000 -U autotest -P autotestlocale is "en_US"locale charset is "ISO-8859-1"Msg 2403, Level 16, State 0, Server OpenClient, Line 0WARNING! Some character(s) could not be converted into client's character set. Unconverted bytes were changed to question marks ('?').1> use atsdb2> go1> select * from auth_function2> goFUNC_ID NAME ENGLISH_NAME PARENT_ID IS_LOG NOTES1>
这说明安装freetds成功
4、配置unixODBC
# cd /usr/local/unixODBC
向ODBC添加SQLServer驱动
# vi etc/odbcinst.ini写入如下内容:[/code]
[ODBC]Trace = YesTraceFile = /tmp/sql.logForceTrace = YesPooling = No
[SQLSERVER]Description = SQLSERVERDriver = /usr/local/freetds/lib/libtdsodbc.soSetup = /usr/local/freetds/lib/libtds.soUsageCount = 1CPTimeout = 5CPReuse = 5FileUsage = 1
保存退出
添加DSN
# vi etc/odbc.ini
写入如下内容
[ATSDB]Driver = SQLSERVER Description = SQLSERVERServer = 192.168.1.110Database = atsdbPort = 1433
注意Driver驱动要写odbcinst.ini中的驱动名称,Database是数据库的名称
保存并退出。
测试ODBC的连接
# bin/isql -v ATSDB autotest autotestSQL>
SQL> quit
OK,测试通过
下面就可以使用freetds的api开发连接sqlserver2000数据库的程序了,可以使用c、c++编写
相关文章推荐
- 在Red hat Linux下通过ODBC连接SQLServer2000
- 虚拟机上装的red hat linux 9通过NAT方式上网配置
- LINUX通过ODBC连接MySQL
- aws中Red Hat Enterprise Linux 7.3安装图形界面以及mac下的VNC连接
- Linux下通过ODBC连接SQL Server
- 用Xmanager远程连接Red hat Enterprise Linux 5
- windows下用虚拟机VMwareRedHatlinux9.0通过nat上网
- Red Hat Enterprise Linux 无法用VNC Viewer连接,报错:无法连接的主机,10065!
- Red Hat Enterprise Linux 无法用VNC Viewer连接,报错:无法连接的主机,10065!
- Red Hat Linux 9通过NAT方式配置网络
- XenServer5.6上通过NFS安装Red hat Enterprise Linux5.5_64bit过程
- 在Linux下使用perl通过unixODBC连接SQLServer2000
- 使用vncviewer成功连接red hat linux server 连接失败:套接字操作尝试一个...
- linux下WMB通过ODBC连接DB2数据库
- 数据库服务器 之 在Linux下使用perl通过unixODBC连接SQLServer2000
- Linux下通过ODBC连接SQL Server
- window xp 装虚拟机Red Hat Linux 6,用ssh、 FlashFXP等工具进行连接
- Windows7旗舰版,通过samba与Red Hat Linux实现资源共享
- Dell 原有PowerEdge 服务器型号获得通过 Red Hat Enterprise Linux 6 认证