国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

在Linux下訪問MS SQL Server數(shù)據(jù)庫 

2024-08-31 00:50:26
字體:
供稿:網(wǎng)友
 linux作為一個免費的Unix類操作系統(tǒng),以其開放性源代碼、多任務(wù)、Xwindow等特點為眾多的用戶所采用,并有很多企業(yè)采用Linux來作為其內(nèi)部網(wǎng)的全功能服務(wù)器(WWW,F(xiàn)TP,Email、DNS)。企業(yè)的內(nèi)部網(wǎng)不僅要提供文本信息的訪問,還要能提供對企業(yè)關(guān)系數(shù)據(jù)庫中的信息的訪問。SQL Server以其低成本、性能高以及與NT的有效集成等特性為許多企業(yè)所采用,但Microsoft不提供其Unix下的客戶端,為這類應(yīng)用帶來了困難。本文則提出了這一問題的解決方案。

安裝Sybase客戶端
  首先從Microsoft SQL Server和Sybase SQL Server的關(guān)系說起。兩公司曾共同開發(fā)OS/2上的數(shù)據(jù)庫SQL Server for OS/2,此后兩公司又獨立開發(fā)升級系統(tǒng),Sybase的客戶端可以訪問Microsoft SQL Server。

  和其他數(shù)據(jù)庫公司相比,可以說Sybase公司對Linux是最有善意的,它雖不提供Linux下的SQL Server,但提供了免費的CT-LIB的客戶端,這也可能是許多IT管理人員在為公司數(shù)據(jù)庫選型時不再考慮Oracle或Informix的理由之一。當(dāng)然現(xiàn)在情況有所改變。

  Sybase公司發(fā)布的OpenClientforLinux是a.out格式的,在互聯(lián)網(wǎng)上有人將其轉(zhuǎn)化為ELF和動態(tài)鏈接的ELF格式,可從下列地址上尋找下載:http://www.mbay.net/~mpeppler。最好同時下載兩個版本,正常使用時采用動態(tài)鏈接的版本,但有的程序在編譯時可能需要一個庫(libblk.a),只在ELF里面包含。

  下載以后,鍵入如下命令展開(假設(shè)當(dāng)前目錄是/usr/tmp):

  tar zxvf linux elf dynamic tar.gz

  然后將其移至/usr/local目錄:

  mv sybase /usr/local

  編譯和使用Sybase客戶端需要進行如下的設(shè)置:

  1.Interface文件舉例如下:

  MSSQL

  Query tcp ether MySQL 1433

  其中:

MSSQL是客戶端使用的服務(wù)器名,以后引用MSSQL即可;

mysql是服務(wù)器的地址或名字,如果是名字,則系統(tǒng)能夠查到其ip地址;

1433是SQL Server的端口號,Microsoft SQL Server的缺省值是1433,Sybase是5000。
  2.SYBASE環(huán)境變量,內(nèi)容是Sybase客戶端所在的目錄:

  ExportSYBASE=/usr/local/sybase

  3.如果編譯Sybase客戶端中的例子,則還要設(shè)置環(huán)境變量SYBPLATFORM:

  export SYBPLATFORM=Linux

  并且修改其頭文件中關(guān)于服務(wù)器名稱及用戶名和口令的描述。

使用SQSH界面訪問SQL Server
  Sybase客戶端提供了xisql工具,但更多的人使用的是SQSH,SQSH是SQshell的縮寫,是改進了的isql,可從下列地址下載:http://www.voicenet.com/~gray/。當(dāng)前的最新版本是1.6.0。假設(shè)下載后的文件放在/usr/tmp目錄下:

  tar zxvf sqsq 1.6.0 tar.gz

  cd sqsh 1.6.0

  ./configure

  make;make install

  然后,將生成的可執(zhí)行文件sqsh安裝到/usr/local/bin/目錄下。

  Sqsh的使用如下:

  #sqsh--Uusername--PpassWord--Sservername

  其中username和password是用戶名和口令,servername是在interface文件中定義的服務(wù)器名(如例子中的MSSQL)。

  Sqsh是交互式的命令行界面,命令用輸入go來執(zhí)行,命令如果較長可直接分成幾行書寫,以回車換行即可。

  如下是一個例子:

  1> use pubs

  2> go

  1> select * from authors

  2> go采用CT-LIB編寫應(yīng)用程序

  由于Sybase的Linux客戶端不提供DB-Library,所以應(yīng)采用CT-Library來編寫應(yīng)用程序,采用CT-Library編寫應(yīng)用程序可參考例子,詳細(xì)的編程說明可以參考Sybase的說明。利用Sybperl編寫應(yīng)用程序

  Sybperl是Sybase的Perl擴展,可利用Perl語言來訪問SQL Server,或者編寫CGI程序。

  Sybperl可從下列地址取得http://www.mbay.net/~mpeppler。當(dāng)前的最新版本是2.9.5。

  取得Sybperl的源代碼展開以后,需要修改一下CONFIG文件,以下是幾個參數(shù):

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

  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_fnamen";
    }
   }
  可以看出,短短幾行語句,就可以完成對數(shù)據(jù)庫的操作。 
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 合川市| 西乌珠穆沁旗| 华蓥市| 秦皇岛市| 仪陇县| 新乡市| 平湖市| 庄浪县| 高青县| 冷水江市| 云南省| 冕宁县| 潞西市| 茶陵县| 长泰县| 杭锦后旗| 彝良县| 瑞金市| 凤山市| 宝兴县| 任丘市| 乐业县| 黔东| 黄浦区| 临猗县| 洛阳市| 安仁县| 容城县| 新营市| 孝义市| 大宁县| 万源市| 余干县| 长治县| 大名县| 盐城市| 苗栗市| 桑日县| 五指山市| 中宁县| 盈江县|