在Linux下訪問MS SQL Server資料庫(轉)
在Linux下訪問MS SQL Server資料庫[@more@]Linux作為一個免費的Unix類作業系統,以其開放性原始碼、多工、X window等特點為眾多的使用者所採用,並有很多企業採用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下的SQLServer,但提供了免費的CT-LIB的客戶端,這也可能是許多IT管理人員在為公司資料庫選型時不再考慮Oracle或Informix的理由之一。當然現在情況有所改變。
Sybase公司釋出的OpenClientforLinux是a.out格式的,在網際網路上有人將其轉化為ELF和動態連結的ELF格式,可從下列地址上尋找下載:~mpeppler。最好同時下載兩個版本,正常使用時採用動態連結的版本,但有的程式在編譯時可能需要一個庫(libblk.a),只在ELF裡面包含。
下載以後,鍵入如下命令展開(假設當前目錄是/usr/tmp):
tarzxvflinux?elf?dynamic?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,可從下列地址下載:~gray/。當前的最新版本是1.6.0。假設下載後的檔案放在/usr/tmp目錄下:
tarzxvfsqsq?1.6.0?tar.gz
cdsqsh?1.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可從下列地址取得~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外,並不需要其他軟體(具體資訊可訪問)。
安裝Sybase客戶端
首先從Microsoft SQL Server和Sybase SQL Server的關係說起。兩公司曾共同開發OS/2上的資料庫SQL Server for OS/2, 此後兩公司又獨立開發升級系統,Sybase的客戶端可以訪問Microsoft SQL Server。
和其他資料庫公司相比,可以說Sybase公司對Linux是最有善意的,它雖不提供Linux下的SQLServer,但提供了免費的CT-LIB的客戶端,這也可能是許多IT管理人員在為公司資料庫選型時不再考慮Oracle或Informix的理由之一。當然現在情況有所改變。
Sybase公司釋出的OpenClientforLinux是a.out格式的,在網際網路上有人將其轉化為ELF和動態連結的ELF格式,可從下列地址上尋找下載:~mpeppler。最好同時下載兩個版本,正常使用時採用動態連結的版本,但有的程式在編譯時可能需要一個庫(libblk.a),只在ELF裡面包含。
下載以後,鍵入如下命令展開(假設當前目錄是/usr/tmp):
tarzxvflinux?elf?dynamic?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,可從下列地址下載:~gray/。當前的最新版本是1.6.0。假設下載後的檔案放在/usr/tmp目錄下:
tarzxvfsqsq?1.6.0?tar.gz
cdsqsh?1.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可從下列地址取得~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外,並不需要其他軟體(具體資訊可訪問)。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10796304/viewspace-952572/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 在Linux下訪問MSSQLServer資料庫 (轉)LinuxSQLServer資料庫
- MS SQL Server 資料庫備份方法SQLServer資料庫
- MS SQL Server資料庫事務鎖機制分析(轉)SQLServer資料庫
- oracle通過透明閘道器(Oracle Transparent Geteways),訪問ms sql server和其他資料庫OracleSQLServer資料庫
- SQL Server 資料訪問策略:CLRMESQLServer
- 在SQL Server下資料庫連結的使用SQLServer資料庫
- Sql Server在.net中的資料訪問輔助類SQLServer
- SQL Server 資料訪問策略:即席SQLCUSQLServer
- MS SQL Server資料庫中合併複製詳解SQLServer資料庫
- Serverless 解惑——函式計算如何訪問 SQL Server 資料庫Server函式SQL資料庫
- 在Oracle裡設定訪問多個SQL Server(轉)OracleSQLServer
- 關於jsp 呼叫bean 訪問sql-server資料庫問題JSBeanSQLServer資料庫
- Python連線三大資料庫MS Sql Server、Oracle、MySQLPython大資料資料庫ServerOracleMySql
- 直接透過ODBC API訪問SQL資料庫 (轉)APISQL資料庫
- MS SQL Server 刪除重複行資料SQLServer
- 使用SqlBulkCopy匯入資料至MS SQL ServerSQLServer
- 實戰oracle gateway訪問sql server2000資料庫OracleGatewaySQLServer資料庫
- Oracle DBLink跨資料庫訪問SQL server資料同步 踩坑實錄Oracle資料庫SQLServer
- 在SQL Server資料庫中匯入MySQL資料庫Server資料庫MySql
- MS SQL Server 2000 系統資料庫及相關資訊SQLServer資料庫
- SQL Server通過dblink訪問Oracle資料SQLServerOracle
- ms sql server排序SQLServer排序
- Sql Server 資料庫超時問題SQLServer資料庫
- sql server 資料庫還原問題SQLServer資料庫
- SQL Server建立使用者只能訪問指定資料庫和檢視SQLServer資料庫
- 移至64位SQL Server資料庫(轉)SQLServer資料庫
- Oracle\MS SQL Server的資料庫多表關聯更新UPDATE與多表更新OracleSQLServer資料庫
- SQL Server資料庫中的資料型別隱式轉換問題SQLServer資料庫資料型別
- SQL Server 資料訪問策略:儲存過程QCSQLServer儲存過程
- 在SQL Server資料庫中匯入匯出資料SQLServer資料庫
- 轉發:C#操作SQL Server資料庫C#SQLServer資料庫
- 用perl訪問mysql資料庫(轉)MySql資料庫
- 遠端資料庫的訪問 (轉)資料庫
- 透過socket訪問資料庫(轉)資料庫
- JSP訪問資料庫大全(轉)JS資料庫
- MySql資料庫C++訪問(轉)MySql資料庫C++
- SQL Server 2005 管理併發資料訪問[zt]SQLServer
- SQL Server資料庫安全SQLServer資料庫