閱讀965 返回首頁    go 阿裏雲 go 技術社區[雲棲]


在Linux(UNIX)下連接MS SQLserver的方法

     一般人看見這個題目時很驚訝,既然使用Linux(UNIX)操作係統,完全可以使用orcaleMYSQL或者PostGreSQL數據庫,並且在LinuxUNIX)係統下使可以更加充分的使用這些數據庫的特性。而MS SQLSERVER不提供LinuxUNIX)版的服務器端(客戶端)安裝,所以無法使用MS SQLSERVER數據庫。

但是現實總是這樣的,在一些情況下(尤其是多個項目組共同開發時),會出現windows下連接LinuxUNIX)數據庫,同樣也會出現在LinuxUNIX)下連接windows下的SQLSERVER數據的情況。下麵我們介紹兩種種方法

1:使用FreeTDS,這是一個能夠用LinuxUnix連接MS SQLServerSybase數據庫的開源組件,下載地址

       https://yq.aliyun.com/articles/ftp://ftp.ibiblio.org/pub/Linux/ALPHA/freetds/stable/freetds-stable.tgz

官方網址:https://www.freetds.org

       使用方法很簡單,裏麵有詳細的幫助文檔,並且這個庫可以在windows下編譯使用,可以很好解決跨平台問題。這樣我們在使用MS SQLSERVER編程時如果需要考慮跨平台使用,就可以通過FreeTDS操作SQLSERVER數據庫。

       使用時隻需配置freetds.conf文件即可,通過這個設置文件設置還可以訪問Sybase數據庫和JDBC   缺點就是,沒有官方支持,如果你熱衷於開源軟件,不妨根據自己的需要修改FreeTDS不失為一個好的方法。不過你需要首先安裝unixODBC
      

2:安裝Sybase客戶端 ,首先從Microsoft SQLServerSybase SQLServer的關係說起。兩公司曾共同開發OS/2上的數據庫SQLServerforOS/2,此後兩公司又獨立開發升級係統,Sybase的客戶端可以訪問MicrosoftSQLServer

  和其他數據庫公司相比,可以說Sybase公司對Linux是最有善意的,它雖不提供Linux下的 SQLServer,但提供了免費的CTLIB的客戶端,這也可能是許多IT管理人員在為公司數據庫選型時不再考慮OracleInformix的理 由之一。當然現在情況有所改變。

Sybase公司發布的OpenClientforLinuxa.out格式的,在互聯網上有人將其轉化為ELF 和動態鏈接的ELF格式,可從下列地址上尋找下載:https://www.mbay.net/mpeppler。最好同時下載兩個版本,正常使用時采用 動態鏈接的版本,但有的程序在編譯時可能需要一個庫(libblk.a),隻在ELF裏麵包含。

下載以後,鍵入如下命令展開(假設當前目錄是/usr/tmp)
tar zxvf linuxelfdynamic.tar.gz
然後將其移至/usr/local目錄:
mvsybase/usr/local
編譯和使用Sybase客戶端需要進行如下的設置:
1
Interface文件舉例如下:
MSSQL
querytcpethermysql1433
其中:MSSQL是客戶端使用的服務器名,以後引用MSSQL即可; mysql是服務器的地址或名字,如果是名字,則係統能夠查到其IP地址; 1433SQLServer的端口號,Microsoft SQL Server的缺省值是1433Sybase5000

2SYBASE環境變量,內容是Sybase客戶端所在的目錄:
ExportSYBASE=/usr/local/sybase
3
.如果編譯Sybase客戶端中的例子,則還要設置環境變量SYBPLATFORM
exportSYBPLATFORM=Linux
並且修改其頭文件中關於服務器名稱及用戶名和口令的描述。使用SQSH界麵訪問SQLServer       由於SybaseLinux客戶端不提供DBLibrary,所以應采用CTLibrary來編寫應用程序,采用CTLibrary編寫應用程序可參考例子,詳細的編程說明可以參考Sybase的說明。利用Sybperl編寫應用程序

SybperlSybasePerl擴展,可利用Perl語言來訪問SQLServer,或者編寫CGI程序。Sybperl可從下列地址取得https://www.mbay.net/mpeppler。當前的最新版本是2.9.5。 取得Sybperl的源代碼展開以後,需要修改一下CONFIG文件,以下是幾個參數:

下一個要修改的文件是PWD,這是用來進行測試的,將其中的服務器名、用戶名、用戶口令設置成自己的配置即可。然後進行編譯:

perlMakefile.PL
make;maketest;makeinstall
安裝成功以後,即可使用Sybperl進行編程。下麵是一個簡單的例子。
!/usr/bin/perl
useSybase::CTlib;
$dbh=newSybase::CTlib'sa',','MSSQL';
$dbh
>ct_execute("selectau_id,au_lname
au_fnamefrompubs.dbo.authors");
while($dbh
>ct_results($restype)==CS_SUCCEED){
nextunless$dbh
>ct_fetchable($restype);
while(($au_id,$au_lname,$au_fname)=$dbh
>ct_fetch){
print"$au_id
$au_lnameau_fname";
}
}
  可以看出,短短幾行語句,就可以完成對數據庫的操作。缺點就是,SQL SERVER升級後可能有不能使用。並且要在LinuxUNIX)下直接開發,對於那些即想跨平台,又想在windows下開發的用戶,無疑是痛苦。

 

 

最後更新:2017-04-02 00:00:28

  上一篇:go 淺談NT下Ring3無驅進入Ring0的方法
  下一篇:go 論項目的倒掉