站長資訊網
        最全最豐富的資訊網站

        linux下如何配置SQLSERVER ODBC

        一 測試環境

        操作系統 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 ( 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 –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 SQLCNBJ015I01, 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

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产精品无码国模私拍视频| 老湿亚洲永久精品ww47香蕉图片| 66精品综合久久久久久久| 久久久久99精品成人片三人毛片| 国产精品2019| 精品麻豆丝袜高跟鞋AV| 精品人妻少妇一区二区三区不卡| 99久久精品影院老鸭窝| 国产中文在线亚洲精品官网| 国模精品一区二区三区| 国产成人精品免费视频大| 真实国产精品vr专区| 国产精品H片在线播放| 九九精品免视看国产成人| 精品偷自拍另类在线观看| 亚洲国产精品综合久久网络 | 精品人妻系列无码人妻免费视频| 亚洲国产精品成| 国产精品视频久久久| 国产在线精品一区二区中文| 日本VA欧美VA欧美VA精品| 亚洲精品字幕在线观看| 亚洲av无码成人精品国产| 久久久久亚洲精品无码网址 | 色偷偷88888欧美精品久久久| 四虎永久在线精品国产馆V视影院| 国产精品久久久久久久午夜片| 日本精品久久久久中文字幕8 | 国产精品成人A区在线观看| 精品无码一区二区三区爱欲九九 | 欧美久久精品一级c片片| 国产精品一区二区不卡| 国产精品久久久福利| 999国内精品永久免费视频| 久久精品国产亚洲AV高清热| 奇米影视7777久久精品| 色久综合网精品一区二区| 人人妻人人澡人人爽人人精品| 无码精品人妻一区二区三区中| 欧产日产国产精品精品| 欧美成人精品高清在线观看|