在Linux(UNIX)下連線MS SQLserver的方法
但是現實總是這樣的,在一些情況下(尤其是多個專案組共同開發時),會出現windows下連線Linux(UNIX)資料庫,同樣也會出現在Linux(UNIX)下連線windows下的SQLSERVER資料的情況。下面我們介紹兩種種方法
1:使用FreeTDS
官方網址:http://www.freetds.org
使用方法很簡單,裡面有詳細的幫助文件,並且這個庫可以在windows下編譯使用,可以很好解決跨平臺問題。這樣我們在使用MS SQLSERVER程式設計時如果需要考慮跨平臺使用,就可以通過FreeTDS操作SQLSERVER資料庫。
使用時只需配置freetds.conf檔案即可,通過這個設定檔案設定還可以訪問Sybase資料庫和JDBC。缺點就是,沒有官方支援,如果你熱衷於開源軟體,不妨根據自己的需要修改FreeTDS不失為一個好的方法。不過你需要首先安裝
2:安裝Sybase客戶端 ,首先從Microsoft SQLServer和Sybase SQLServer的關係說起。兩公司曾共同開發OS/2上的資料庫SQLServerforOS/2,此後兩公司又獨立開發升級系統,Sybase的客戶端可以訪問MicrosoftSQLServer。
和其他資料庫公司相比,可以說Sybase公司對Linux是最有善意的,它雖不提供Linux下的 SQLServer,但提供了免費的CT-LIB的客戶端,這也可能是許多IT管理人員在為公司資料庫選型時不再考慮Oracle或Informix的理 由之一。當然現在情況有所改變。
Sybase公司釋出的OpenClientforLinux
下載以後,鍵入如下命令展開(假設當前目錄是/usr/tmp):
tar zxvf linuxelfdynamic.tar.gz
然後將其移至/usr/local目錄:
mvsybase/usr/local
編譯和使用Sybase客戶端需要進行如下的設定:
1.Interface檔案舉例如下:
MSSQL
querytcpethermysql1433
其中:MSSQL是客戶端使用的伺服器名,以後引用MSSQL即可; mysql是伺服器的地址或名字,如果是名字,則系統能夠查到其IP地址; 1433是SQLServer的埠號,Microsoft SQL Server的預設值是1433,Sybase是5000。
2.SYBASE環境變數,內容是Sybase客戶端所在的目錄:
ExportSYBASE=/usr/local/sybase
3.如果編譯Sybase客戶端中的例子,則還要設定環境變數SYBPLATFORM
exportSYBPLATFORM=Linux
並且修改其標頭檔案中關於伺服器名稱及使用者名稱和口令的描述。使用SQSH介面訪問SQLServer 由於Sybase的Linux客戶端不提供DB-Library,所以應採用CT-Library來編寫應用程式,採用CT-Library編寫應用程式可參考例子,詳細的程式設計說明可以參考Sybase的說明。利用Sybperl編寫應用程式
Sybperl是Sybase的Perl擴充套件,可利用Perl語言來訪問SQLServer,或者編寫CGI程式。Sybperl可從下列地址取得http://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升級後可能有不能使用。並且要在Linux(UNIX)下直接開發,對於那些即想跨平臺,又想在windows下開發的使用者,無疑是痛苦。