Linux作為一個(gè)免費(fèi)的Unix類操作系統(tǒng),以其開(kāi)放性源代碼、多任務(wù)、X-window等特點(diǎn)為眾多的用戶所采用,并有很多企業(yè)采用Linux來(lái)作為其內(nèi)部網(wǎng)的全功能服務(wù)器(WWW,F(xiàn)TP,Email、DNS)。企業(yè)的內(nèi)部網(wǎng)不僅要提供文本信息的訪問(wèn),還要能提供對(duì)企業(yè)關(guān)系數(shù)據(jù)庫(kù)中的信息的訪問(wèn)。SQLServer以其低成本、性能高以及與NT的有效集成等特性為許多企業(yè)所采用,但Microsoft不提供其Unix下的客戶端,為這類應(yīng)用帶來(lái)了困難。本文則提出了這一問(wèn)題的解決方案。
安裝Sybase客戶端
首先從Microsoft SQLServer和Sybase SQLServer的關(guān)系說(shuō)起。兩公司曾共同開(kāi)發(fā)OS/2上的數(shù)據(jù)庫(kù)SQLServerforOS/2,此后兩公司又獨(dú)立開(kāi)發(fā)升級(jí)系統(tǒng),Sybase的客戶端可以訪問(wèn)MicrosoftSQLServer。
和其他數(shù)據(jù)庫(kù)公司相比,可以說(shuō)Sybase公司對(duì)Linux是最有善意的,它雖不提供Linux下的SQLServer,但提供了免費(fèi)的CT-LIB的客戶端,這也可能是許多IT管理人員在為公司數(shù)據(jù)庫(kù)選型時(shí)不再考慮Oracle或Informix的理由之一。當(dāng)然現(xiàn)在情況有所改變。
Sybase公司發(fā)布的OpenClientforLinux是a.out格式的,在互聯(lián)網(wǎng)上有人將其轉(zhuǎn)化為ELF和動(dòng)態(tài)鏈接的ELF格式,可從下列地址上尋找下載:http://www.mbay.net/~mpeppler。同時(shí)下載兩個(gè)版本,正常使用時(shí)采用動(dòng)態(tài)鏈接的版本,但有的程序在編譯時(shí)可能需要一個(gè)庫(kù)(libblk.a),只在ELF里面包含。
下載以后,鍵入如下命令展開(kāi)(假設(shè)當(dāng)前目錄是/usr/tmp):
tar zxvf linuxelfdynamic.tar.gz
然后將其移至/usr/local目錄:
mvsybase/usr/local
編譯和使用Sybase客戶端需要進(jìn)行如下的設(shè)置:
1.Interface文件舉例如下:
MSSQL
querytcpethermysql1433
其中:
MSSQL是客戶端使用的服務(wù)器名,以后引用MSSQL即可;
mysql是服務(wù)器的地址或名字,如果是名字,則系統(tǒng)能夠查到其IP地址;
1433是SQLServer的端口號(hào),MicrosoftSQLServer的缺省值是1433,Sybase是5000。
2.SYBASE環(huán)境變量,內(nèi)容是Sybase客戶端所在的目錄:
ExportSYBASE=/usr/local/sybase
3.如果編譯Sybase客戶端中的例子,則還要設(shè)置環(huán)境變量SYBPLATFORM:
exportSYBPLATFORM=Linux
并且修改其頭文件中關(guān)于服務(wù)器名稱及用戶名和口令的描述。
安裝Sybase客戶端
首先從Microsoft SQLServer和Sybase SQLServer的關(guān)系說(shuō)起。兩公司曾共同開(kāi)發(fā)OS/2上的數(shù)據(jù)庫(kù)SQLServerforOS/2,此后兩公司又獨(dú)立開(kāi)發(fā)升級(jí)系統(tǒng),Sybase的客戶端可以訪問(wèn)MicrosoftSQLServer。
和其他數(shù)據(jù)庫(kù)公司相比,可以說(shuō)Sybase公司對(duì)Linux是最有善意的,它雖不提供Linux下的SQLServer,但提供了免費(fèi)的CT-LIB的客戶端,這也可能是許多IT管理人員在為公司數(shù)據(jù)庫(kù)選型時(shí)不再考慮Oracle或Informix的理由之一。當(dāng)然現(xiàn)在情況有所改變。
Sybase公司發(fā)布的OpenClientforLinux是a.out格式的,在互聯(lián)網(wǎng)上有人將其轉(zhuǎn)化為ELF和動(dòng)態(tài)鏈接的ELF格式,可從下列地址上尋找下載:http://www.mbay.net/~mpeppler。同時(shí)下載兩個(gè)版本,正常使用時(shí)采用動(dòng)態(tài)鏈接的版本,但有的程序在編譯時(shí)可能需要一個(gè)庫(kù)(libblk.a),只在ELF里面包含。
下載以后,鍵入如下命令展開(kāi)(假設(shè)當(dāng)前目錄是/usr/tmp):
tar zxvf linuxelfdynamic.tar.gz
然后將其移至/usr/local目錄:
mvsybase/usr/local
編譯和使用Sybase客戶端需要進(jìn)行如下的設(shè)置:
1.Interface文件舉例如下:
MSSQL
querytcpethermysql1433
其中:
MSSQL是客戶端使用的服務(wù)器名,以后引用MSSQL即可;
mysql是服務(wù)器的地址或名字,如果是名字,則系統(tǒng)能夠查到其IP地址;
1433是SQLServer的端口號(hào),MicrosoftSQLServer的缺省值是1433,Sybase是5000。
2.SYBASE環(huán)境變量,內(nèi)容是Sybase客戶端所在的目錄:
ExportSYBASE=/usr/local/sybase
3.如果編譯Sybase客戶端中的例子,則還要設(shè)置環(huán)境變量SYBPLATFORM:
exportSYBPLATFORM=Linux
并且修改其頭文件中關(guān)于服務(wù)器名稱及用戶名和口令的描述。