在Linux下訪問MS SQL Server資料庫

來源:互聯網
上載者:User

Linux作為一個免費的Unix類作業系統,以其開放性原始碼、多任務、X-window等特點為眾多的使用者所採用,並有很多企業採用Linux來作為其內部網的全功能伺服器(WWW,FTP,Email、DNS)。企業的內部網不僅要提供文本資訊的訪問,還要能提供對企業關聯式資料庫中的資訊的訪問。SQLServer以其低成本、效能高以及與NT的有效整合等特性為許多企業所採用,但Microsoft不提供其Unix下的用戶端,為這類應用帶來了困難。本文則提出了這一問題的解決方案。

 

安裝Sybase用戶端

 

首先從Microsoft SQLServer和Sybase SQLServer的關係說起。兩公司曾共同開發OS/2上的資料庫SQLServerforOS/2,此後兩公司又獨立開發升級系統,Sybase的用戶端可以訪問MicrosoftSQLServer。

 

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

 

Sybase公司發布的OpenClientforLinux是a.out格式的,在互連網上有人將其轉化為ELF和動態連結的ELF格式,可從下列地址上尋找下載:http://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地址;

 

1433是SQLServer的連接埠號碼,MicrosoftSQLServer的預設值是1433,Sybase是5000。

 

2.SYBASE環境變數,內容是Sybase用戶端所在的目錄:

 

ExportSYBASE=/usr/local/sybase

 

3.如果編譯Sybase用戶端中的例子,則還要設定環境變數SYBPLATFORM:

 

exportSYBPLATFORM=Linux

 

並且修改其標頭檔中關於伺服器名稱及使用者名稱和口令的描述。

 

使用SQSH介面訪問SQLServer

 

Sybase用戶端提供了xisql工具,但更多的人使用的是SQSH,SQSH是SQshell的縮寫,是改進了的isql,可從下列地址下載:http://www.voicenet.com/~gray/。當前的最新版本是1.6.0。假設下載後的檔案放在/usr/tmp目錄下:

 


  tar zxvf sqsq1.6.0.tar.gz  cdsqsh1.6.0  ./configure  make;makeinstall

然後,將產生的可執行檔sqsh安裝到/usr/local/bin/目錄下。

 

Sqsh的使用如下:

 


  #sqsh--Uusername--Ppassword--Sservername

 

 

其中username和password是使用者名稱和口令,servername是在interface檔案中定義的伺服器名(如例子中的MSSQL)。

 

Sqsh是互動命令列介面,命令用輸入go來執行,命令如果較長可直接分成幾行書寫,以斷行符號換行即可。

 

如下是一個例子:

 


  1>usepubs  2>go  1>select*fromauthors  2>go採用CT-LIB編寫應用程式

 

 

 

 

 

由於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";    }    }

 

可以看出,短短几行語句,就可以完成對資料庫的操作。

 

以上從幾個方面對在Linux下訪問MSSQLServer資料庫進行了說明,介紹了基本的API編程、SQSH命令列訪問、Perl訪問。其實,在Linux下還可採用其他方式進行訪問,如採用第四級的JDBC進行訪問,這時除了Java和JDBC外,並不需要其他軟體(具體資訊可訪問http://www.connectsw.com)。

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.