全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1658
推到 Plurk!
推到 Facebook!

在Linux下訪問MS SQL Server資料庫

 
conundrum
尊榮會員


發表:893
回覆:1272
積分:643
註冊:2004-01-06

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-01-09 23:31:15 IP:220.143.xxx.xxx 未訂閱
 在Linux下訪問MS SQL Server資料庫 
藍森林 http://www.lslnet.com       Linux作為一個免費的Unix類作業系統,以其開放性源代碼、多工、XQwindow等特點為眾多的用戶所採用,並有很多企業採用Linux來作為其內部網的全功能伺服器(WWW,FTP,Email、DNS)。企業的內部網不僅要提供文本資訊的訪問,還要能提供對企業關聯資料庫中的資訊的訪問。SQL Server以其低成本、性能高以及與NT的有效集成等特性為許多企業所採用,但Microsoft不提供其Unix下的用戶端,為這類應用帶來了困難。本文則提出了這一問題的解決方案。 
安裝Sybase用戶端
  首先從Microsoft SQL Server和Sybase SQL Server的關係說起。兩公司曾共同開發OS/2上的資料庫SQL Server for OS/2,此後兩公司又獨立開發升級系統,Sybase的用戶端可以訪問Microsoft SQL Server。 
  和其他資料庫公司相比,可以說Sybase公司對Linux是最有善意的,它雖不提供Linux下的SQL Server,但提供了免費的CT-LIB的用戶端,這也可能是許多IT管理人員在為公司資料庫選型時不再考慮Oracle或Informix的理由之一。當然現在情況有所改變。 
  Sybase公司發佈的OpenClientforLinux是a.out格式的,在互聯網上有人將其轉化為ELF和動態鏈結的ELF格式,可從下列地址上尋找下載:http://www.mbay.net/~mpeppler。最好同時下載兩個版本,正常使用時採用動態鏈結的版本,但有的程式在編譯時可能需要一個庫(libblk.a),只在ELF裏面包含。 
  下載以後,鍵入如下命令展開(假設當前目錄是/usr/tmp): 
  tar zxvf linux Qelf Qdynamic Qtar.gz 
  然後將其移至/usr/local目錄: 
  mv sybase /usr/local 
  編譯和使用Sybase用戶端需要進行如下的設置: 
  1.Interface文件舉例如下: 
  MSSQL 
  Query tcp ether mysql 1433 
  其中: 
MSSQL是用戶端使用的伺服器名,以後引用MSSQL即可; 
mysql是伺服器的地址或名字,如果是名字,則系統能夠查到其IP位址; 
1433是SQL Server的埠號,Microsoft SQL Server的缺省值是1433,Sybase是5000。
  2.SYBASE環境變數,內容是Sybase用戶端所在的目錄: 
  ExportSYBASE=/usr/local/sybase 
  3.如果編譯Sybase用戶端中的例子,則還要設置環境變數SYBPLATFORM: 
  export SYBPLATFORM=Linux 
  並且修改其頭檔中關於伺服器名稱及用戶名和口令的描述。 
使用SQSH介面訪問SQL Server 
  Sybase用戶端提供了xisql工具,但更多的人使用的是SQSH,SQSH是SQshell的縮寫,是改進了的isql,可從下列地址下載:http://www.voicenet.com/~gray/。當前的最新版本是1.6.0。假設下載後的檔放在/usr/tmp目錄下: 
  tar zxvf sqsq Q1.6.0 Qtar.gz 
  cd sqsh Q1.6.0 
  ./configure 
  make;make install 
  然後,將生成的可執行檔sqsh安裝到/usr/local/bin/目錄下。 
  Sqsh的使用如下: 
  #sqsh--Uusername--Ppassword--Sservername 
  其中username和password是用戶名和口令,servername是在interface檔中定義的伺服器名(如例子中的MSSQL)。 
  Sqsh是互動式的命令行介面,命令用輸入go來執行,命令如果較長可直接分成幾行書寫,以回車換行即可。 
  如下是一個例子: 
  1> use pubs 
  2> go 
  1> select * from authors 
  2> go採用CT-LIB編寫應用程式 
  由於Sybase的Linux用戶端不提供DB-Library,所以應採用CT-Library來編寫應用程式,採用CT-Library編寫應用程式可參考例子,詳細的編程說明可以參考Sybase的說明。利用Sybperl編寫應用程式 
  Sybperl是Sybase的Perl擴展,可利用Perl語言來訪問SQL Server,或者編寫CGI程式。 
  Sybperl可從下列地址取得http://www.mbay.net/~mpeppler。當前的最新版本是2.9.5。 
  取得Sybperl的源代碼展開以後,需要修改一下CONFIG檔,以下是幾個參數: 
  下一個要修改的檔是PWD,這是用來進行測試的,將其中的伺服器名、用戶名、用戶口令設置成自己的配置即可。然後進行編譯: 
  perl Makefile.PL 
  make; make test; make install 
  安裝成功以後,即可使用Sybperl進行編程。下面是一個簡單的例子。 
    #!/usr/bin/perl 
   use Sybase::CTlib; 
    $dbh=new Sybase::CTlib 'sa','','MSSQL'; 
    $dbh ->ct_execute("select au_id, au_lname, 
au_fname from pubs.dbo.authors"); 
   while( $dbh ->ct_results( $restype) == CS_SUCCEED) { 
    next unless $dbh ->ct_fetchable( $restype); 
while(( $au_id, $au_lname, $au_fname) = $dbh ->ct_fetch){ 
    print " $au_id - $au_lname au_fname\n"; 
    } 
   } 
  可以看出,短短幾行語句,就可以完成對資料庫的操作。    ——摘自:http://linux.joyo.com    
系統時間:2024-05-14 18:29:08
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!