linux下如何配置SQLSERVER ODBC
一测试环境
操作系统RedHatAs5.5
数据库
SQLServer2000installedinwindowsxpprofessional,我假定数据库有用户autotest密码是autotest,数据库文件是atsdb
注意:
1MS从来没有提供过SQLServerforLinux,所以大家也不要去尝试在Linux系统安装SQLServer,但是可以通过ODBC连接
Windows系统的SQLServer数据库;
2安装的SQLServer2000是不会打开1433端口的,所以请Windowsxp用户在安装完SQLServer之后一定装上SQLServerSP3布丁,可以使用命令netstat-a来查看是否打开1433端口
3对于windowsxp,缺省防火墙是不让1433端口来通讯的,所以必须关掉windows的防火墙,这个问题折腾我一天,老是连接不成功,我还以为是odbc软件的配置问题,教训呀。最可气的是在别的windows机器使用sqlserver的命令isql能够访问数据库,(不用关闭防火墙)。通过抓包工具发现根本就不通过1433端口通讯,而是通过445或139内部端口通讯呀,真要命呀,看来windowns东西是好,但是也太霸道了呀
4在xpsp2安装sqlserver2000时必须要打chs_sql2ksp3.exe补丁,如果没有这个补丁,telnetip1433会连接不了,当然从远程客户端连接不上,就这个问题折腾一个下午,晕呀
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
#tarvxzfunixODBC-2.2.8.tar.gz
#cdunixODBC-2.2.8
#./configure--prefix=/usr/local/unixODBC--enable-gui=no
#make
#makeinstall
2、安装freetds
#tarvxzffreetds-0.62.4.tar.gz
#cdfreetds-0.62.4
#./configure--prefix=/usr/local/freetds--with-unixodbc=/usr/local/unixODBC--with-tdsver=8.0
#make
#makeinstall
3、配置freetds
#vi/usr/local/freetds/etc/freetds.conf
修改以下的一段,并把;去掉
改好之后的内容:
[global]
#TDSprotocolversion
tdsversion=8.0
[SQLServer2000]
host=192.168.1.110
port=1433
tdsversion=8.0
clientcharset=ISO-8859-1
[SQLServerMDM]
host=SQLCNBJ015.corp.novocorp.net
port=3888
# instance=MDM_StagingDB
tdsversion=8.0
clientcharset=UTF-8
其中的[SQLServer2000]代表在客户端使用的服务器名称(在tsql命令中要加入-SSQLServer2000),host代表SQLServer服务器的IP地址,port代表端口.clientcharset是客户端使用的字符集,我的机器使用utf-8会报连接失败的错误,发现tsql使用ISO-8859-1字符集可以连接成功,所以这儿也改成这样
测试连接:
$tsql-SSQLServer2000-Uautotest-Pautotest
./tsql-SSQLServerDEV-USELASReader-POnly4SELAS
localeis"en_US"
localecharsetis"ISO-8859-1"
Msg2403,Level16,State0,ServerOpenClient,Line0
WARNING!Somecharacter(s)couldnotbeconvertedintoclient"scharacterset.Unconvertedbyteswerechangedtoquestionmarks("?").
1>useatsdb
2>go
1>select*fromauth_function
2>go
FUNC_IDNAME ENGLISH_NAME PARENT_ID IS_LOGNOTES
1>
[siebel@appcnbj035bin]$./tsql-SSQLServerMDM-USELASReader-POnly4SELAS
localeis"LC_CTYPE=en_US.UTF-8;LC_NUMERIC=zh_CN.GB18030;LC_TIME=zh_CN.GB18030;LC_COLLATE=zh_CN.GB18030;LC_MONETARY=zh_CN.GB18030;LC_MESSAGES=zh_CN.GB18030;LC_PAPER=zh_CN.GB18030;LC_NAME=zh_CN.GB18030;LC_ADDRESS=zh_CN.GB18030;LC_TELEPHONE=zh_CN.GB18030;LC_MEASUREMENT=zh_CN.GB18030;LC_IDENTIFICATION=zh_CN.GB18030"
localecharsetis"UTF-8"
Msg5703,Level0,State1,ServerSQLCNBJ015\I01,Line1
Changedlanguagesettingtous_english.
1>selectcount(*)fromV_Standard_STAFF;
2>go;
这说明安装freetds成功
4、配置unixODBC
#cd/usr/local/unixODBC/etc
向ODBC添加SQLServer驱动
#vi/usr/local/unixODBC/etcodbcinst.ini
写入如下内容:
[ODBC]
Trace =Yes
TraceFile =/tmp/sql.log
ForceTrace =Yes
Pooling =No
[SQLSERVER]
Description =SQLSERVER
Driver =/usr/local/freetds/lib/libtdsodbc.so
Setup =/usr/local/freetds/lib/libtds.so
UsageCount =1
CPTimeout =5
CPReuse =5
FileUsage =1
保存退出
添加DSN
#vi/usr/local/unixODBC/etc/odbc.ini
写入如下内容
[ATSDB]
Driver =SQLSERVER
Description =SQLSERVER
Server =192.168.1.110
Database =atsdb
Port =1433
[ATSDB] =SQLSERVER
Description =SQLSERVER
Server =SQLCNBJ015.corp.novocorp.net
Database =MDM_StagingDB
Port =3888
注意Driver驱动要写odbcinst.ini中的驱动名称,Database是数据库的名称
保存并退出。
测试ODBC的连接
#bin/isql-vATSDBautotestautotest Cd/usr/local/unixODBC/bin ./isql-vATSDBSELASReaderOnly4SELAS SQL> SQL>quit