在Linux下訪問MSSQLServer資料庫 (轉)
在Linux下訪問MSSQLServer資料庫 (轉)[@more@]----作為一個免費的類操作,以其開放性、多工、X?window等特點為眾多的所採用,並有很多企業採用Linux來作為其內部網的全功能(WWW,,E、)。企業的內部網不僅要提供文字資訊的訪問,還要能提供對企業關係中的資訊的訪問。Server以其低成本、高以及與NT的有效整合等特性為許多企業所採用,但不提供其Unix下的客戶端,為這類應用帶來了困難。本文則提出了這一問題的解決方案。
客戶端
----首先從MicrosoftSQLServer和SybaseSQLServer的關係說起。兩公司曾共同開發OS/2上的資料庫SQLServerforOS/2,此後兩公司又獨立開發升級系統,Sybase的客戶端可以訪問MicrosoftSQLServer。
----和其他資料庫公司相比,可以說Sybase公司對Linux是最有善意的,它雖不提供Linux下的SQLServer,但提供了免費的CT-LIB的客戶端,這也可能是許多IT管理人員在為公司資料庫選型時不再考慮或Infox的理由之一。當然現在情況有所改變。
----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
----querytcpether1433
----其中:
MSSQL是客戶端使用的伺服器名,以後引用MSSQL即可;
mysql是伺服器的地址或名字,如果是名字,則系統能夠查到其;
1433是SQLServer的埠號,MicrosoftSQLServer的預設值是1433,Sybase是5000。
----2.SYBASE環境變數,內容是Sybase客戶端所在的目錄:
----ExportSYBASE=/usr/local/sybase
----3.如果編譯Sybase客戶端中的例子,則還要設定環境變數SYBPLATFORM:
----exportSYBPLATFORM=Linux
----並且修改其標頭檔案中關於伺服器名稱及使用者名稱和口令的描述。
使用SQSH介面訪問SQLServer
----Sybase客戶端提供了xisql工具,但更多的人使用的是SQSH,SQSH是SQ的縮寫,是改進了的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--Ppass--Sservername
----其中username和password是使用者名稱和口令,servername是在interface檔案中定義的伺服器名(如例子中的MSSQL)。
----Sqsh是互動式的命令列介面,命令用輸入go來執行,命令如果較長可直接分成幾行書寫,以回車換行即可。
----如下是一個例子:
----1>usepubs
----2>go
----1>*fromauthors
----2>go採用CT-LIB編寫應用程式
----由於Sybase的Linux客戶端不提供-Library,所以應採用CT-Library來編寫應用程式,採用CT-Library編寫應用程式可參考例子,詳細的說明可以參考Sybase的說明。利用Syb編寫應用程式
----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_fnamen";
}
}
----可以看出,短短几行語句,就可以完成對資料庫的操作。
----以上從幾個方面對在Linux下訪問MSSQLServer資料庫進行了說明,介紹了基本的程式設計、SQSH命令列訪問、Perl訪問。其實,在Linux下還可採用其他方式進行訪問,如採用第四級的進行訪問,這時除了和JDBC外,並不需要其他(具體資訊可訪問)。
客戶端
----首先從MicrosoftSQLServer和SybaseSQLServer的關係說起。兩公司曾共同開發OS/2上的資料庫SQLServerforOS/2,此後兩公司又獨立開發升級系統,Sybase的客戶端可以訪問MicrosoftSQLServer。
----和其他資料庫公司相比,可以說Sybase公司對Linux是最有善意的,它雖不提供Linux下的SQLServer,但提供了免費的CT-LIB的客戶端,這也可能是許多IT管理人員在為公司資料庫選型時不再考慮或Infox的理由之一。當然現在情況有所改變。
----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
----querytcpether1433
----其中:
MSSQL是客戶端使用的伺服器名,以後引用MSSQL即可;
mysql是伺服器的地址或名字,如果是名字,則系統能夠查到其;
1433是SQLServer的埠號,MicrosoftSQLServer的預設值是1433,Sybase是5000。
----2.SYBASE環境變數,內容是Sybase客戶端所在的目錄:
----ExportSYBASE=/usr/local/sybase
----3.如果編譯Sybase客戶端中的例子,則還要設定環境變數SYBPLATFORM:
----exportSYBPLATFORM=Linux
----並且修改其標頭檔案中關於伺服器名稱及使用者名稱和口令的描述。
使用SQSH介面訪問SQLServer
----Sybase客戶端提供了xisql工具,但更多的人使用的是SQSH,SQSH是SQ的縮寫,是改進了的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--Ppass--Sservername
----其中username和password是使用者名稱和口令,servername是在interface檔案中定義的伺服器名(如例子中的MSSQL)。
----Sqsh是互動式的命令列介面,命令用輸入go來執行,命令如果較長可直接分成幾行書寫,以回車換行即可。
----如下是一個例子:
----1>usepubs
----2>go
----1>*fromauthors
----2>go採用CT-LIB編寫應用程式
----由於Sybase的Linux客戶端不提供-Library,所以應採用CT-Library來編寫應用程式,採用CT-Library編寫應用程式可參考例子,詳細的說明可以參考Sybase的說明。利用Syb編寫應用程式
----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_fnamen";
}
}
----可以看出,短短几行語句,就可以完成對資料庫的操作。
----以上從幾個方面對在Linux下訪問MSSQLServer資料庫進行了說明,介紹了基本的程式設計、SQSH命令列訪問、Perl訪問。其實,在Linux下還可採用其他方式進行訪問,如採用第四級的進行訪問,這時除了和JDBC外,並不需要其他(具體資訊可訪問)。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752043/viewspace-988345/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- JDBC資料庫訪問JDBC資料庫
- Oracle資料庫限制訪問IPOracle資料庫
- 外網訪問MySQL資料庫MySql資料庫
- 使用 @NoRepositoryBean 簡化資料庫訪問Bean資料庫
- 如何限制ip訪問Oracle資料庫Oracle資料庫
- jmeter 使用 ssh 方式訪問資料庫JMeter資料庫
- 【磐維資料庫】透過python訪問磐維資料庫資料庫Python
- Sqlserver限制賬戶在哪些ip下才可以訪問資料庫SQLServer資料庫
- 解決linux下redis資料庫overcommit_memory問題LinuxRedis資料庫MIT
- 在Golang中如何正確地使用database/sql包訪問資料庫GolangDatabaseSQL資料庫
- 資料庫訪問幾種方式對比資料庫
- [開源] .Net ORM 訪問 Firebird 資料庫ORM資料庫
- Xamarin SQLite教程資料庫訪問與生成SQLite資料庫
- Python學習之旅:訪問MySQL資料庫PythonMySql資料庫
- Linux下安裝Mysql資料庫LinuxMySql資料庫
- jdbc訪問KingbaseES資料庫SocketTimeoutException Read timed outJDBC資料庫Exception
- 3.2.4 開啟資料庫到限制訪問模式資料庫模式
- Pandas庫基礎分析——資料生成和訪問
- Holer實現外網訪問SQLServer資料庫SQLServer資料庫
- Holer實現MongoDB資料庫外網訪問MongoDB資料庫
- Holer實現外網訪問MariaDB資料庫資料庫
- Holer實現外網訪問PostgreSQL資料庫SQL資料庫
- Oracle透明閘道器訪問SQLServer資料庫OracleSQLServer資料庫
- Oracle透明閘道器訪問MySQL資料庫OracleMySql資料庫
- Java訪問資料庫的具體步驟:Java資料庫
- 修改防火牆規則,開放 Linux 的 3306 埠,外部訪問 MySQL 資料庫防火牆LinuxMySql資料庫
- OH解決linux下redis資料庫overcommit_memory問題vlrLinuxRedis資料庫MIT
- 【磐維資料庫】Oracle(透明閘道器)訪問磐維資料庫(PanWeiDB)資料庫Oracle
- Linux系統下資料庫有哪些?Linux資料庫
- 刪除linux下的oracle資料庫LinuxOracle資料庫
- Linux下Java剪貼簿的訪問LinuxJava
- Linux下設定redis訪問密碼LinuxRedis密碼
- Spring資料訪問Spring
- 解決資料庫高併發訪問瓶頸問題資料庫
- 【資料庫資料恢復】linux系統下MYSQL資料庫資料恢復案例資料庫資料恢復LinuxMySql
- derby 資料庫 伺服器模式 無法訪問資料庫伺服器模式
- 資料庫mysql如何訪問控制?有哪些階段?資料庫MySql
- 如何從公網訪問內網MongoDB資料庫內網MongoDB資料庫
- 怎樣從外網網訪問本地資料庫?資料庫