当前位置: 移动技术网 > IT编程>开发语言>正则 > linux下如何配置SQLSERVER ODBC

linux下如何配置SQLSERVER ODBC

2017年12月08日  | 移动技术网IT编程  | 我要评论
一 测试环境 操作系统 red hat as 5.5 数据库    sqlserver2000 installed in wind

一 测试环境

操作系统 red hat as 5.5

数据库   

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 ( )

连接sqlserver或sybase的驱动           

     freetds-0.62.4.tar.gz ( )

二 安装配置(必须在root下用户安装)

1、安装unixodbc

# tar vxzf unixodbc-2.2.8.tar.gz
# cd unixodbc-2.2.8
# ./configure --prefix=/usr/local/unixodbc --enable-gui=no
# make
# make install

2、安装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

# vi /usr/local/freetds/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
[sqlservermdm]
        host =sqlcnbj015.corp.novocorp.net
        port =3888
#       instance = mdm_stagingdb
        tds version = 8.0
        client charset = utf-8

其中的[sqlserver2000]代表在客户端使 用的服务器名称(在tsql命令中要加入 -s sqlserver2000),host代表sqlserver服务器的ip地址,port代表端口.client charset 是客户端使用的字符集,我的机器使用utf-8会报连接失败的错误,发现tsql使用iso-8859-1字符集可以连接成功,所以这儿也改成这样

测试连接:

$ tsql -s sqlserver2000 -u autotest -p autotest
./tsql -s sqlserverdev -u selasreader -p only4selas
locale is "en_us"
locale charset is "iso-8859-1"
msg 2403, level 16, state 0, server openclient, line 0
warning! some character(s) could not be converted into client"s character set. unconverted bytes were changed to question marks ("?").
1> use atsdb
2> go
1> select * from auth_function
2> go
func_id name    english_name    parent_id       is_log notes
1>
[siebel@appcnbj035 bin]$ ./tsql -s sqlservermdm -u selasreader -p only4selas
locale is "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"
locale charset is "utf-8"
msg 5703, level 0, state 1, server sqlcnbj015\i01, line 1
changed language setting to us_english.
1> select count(*) from v_standard_staff ;
2> go;

这说明安装freetds成功

4、配置unixodbc

# cd /usr/local/unixodbc/etc

向odbc添加sqlserver驱动

# vi /usr/local/unixodbc/etc odbcinst.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 -v atsdb autotest autotest
cd /usr/local/unixodbc/bin
./isql -v atsdb selasreader only4selas
sql>
sql> quit

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网