ruby DBI安裝使用指南
1.安裝
首先,我是使用mysql進行測試的,你的機器上需要安裝mysql資料庫。
然後執行:
gem install mysql
到rubyforge下載ruby-DBI,解壓後cd到目錄執行如下命令:
ruby setup.rb config --with=dbi,dbd_mysql
ruby setup.rb setup
ruby setup.rb install
完整的setup命令引數參考DBI的doc
2.完整例子
DBI是一類似於ODBC的開發式的統一的資料庫程式設計介面,結構層次上可以分為兩層:
1.Database Interface——資料庫介面層,與資料庫無關,提供與資料庫無關的標準介面
2.Database Driver——資料庫驅動,與資料庫相關
DBI也是很簡單易用的,一個完整的使用例子,對於初學者可能有點幫助:
首先,我是使用mysql進行測試的,你的機器上需要安裝mysql資料庫。
然後執行:
gem install mysql
到rubyforge下載ruby-DBI,解壓後cd到目錄執行如下命令:
ruby setup.rb config --with=dbi,dbd_mysql
ruby setup.rb setup
ruby setup.rb install
完整的setup命令引數參考DBI的doc
2.完整例子
DBI是一類似於ODBC的開發式的統一的資料庫程式設計介面,結構層次上可以分為兩層:
1.Database Interface——資料庫介面層,與資料庫無關,提供與資料庫無關的標準介面
2.Database Driver——資料庫驅動,與資料庫相關
DBI也是很簡單易用的,一個完整的使用例子,對於初學者可能有點幫助:
require 'dbi'
begin
#連線資料庫
dbh=DBI.connect("DBI:Mysql:dbi_test:localhost","root","")
dbh.columns("simple").each do |h|
p h
end
#示範3種事務處理方式
#手動commit
dbh["AutoCommit"]=false
1.upto(10) do |i|
sql = "insert into simple (name, author) VALUES (?, ?)"
dbh.do(sql, "Song #{i}", "#{i}")
end
dbh.commit
#使用transaction方法
dbh.transaction do |dbh|
1.upto(10) do |i|
sql = "insert into simple (name, author) VALUES (?, ?)"
dbh.do(sql, "Song #{i}", "#{i}")
end
end
#使用SQL語句
dbh.do("SET AUTOCOMMIT=0")
dbh.do("BEGIN")
dbh["AutoCommit"]=false
dbh.do("UPDATE simple set name='test' where id='1'")
dbh.do("COMMIT")
#查詢
sth=dbh.execute("select count(id) from simple")
puts "bookCount:#{sth.fetch[0]}"
sth.finish
begin
sth=dbh.prepare("select * from simple")
sth.execute
while row=sth.fetch do
p row
end
sth.finish
rescue
end
#上面這段查詢可以改寫為:
#dbh.select_all("select * from simple") do |row|
# p row
#end
#使用工具類輸出xml格式結果集以及測量查詢時間
sql="select * from simple"
mesuretime=DBI::Utils::measure do
sth=dbh.execute(sql)
end
puts "SQL:#{sql}"
puts "Time:#{mesuretime}"
rows=sth.fetch_all
col_names=sth.column_names
sth.finish
puts DBI::Utils::XMLFormatter.table(rows)
dbh.do("delete from simple")
rescue DBI::DatabaseError=>e
puts "error code:#{e.err}"
puts "Error message:#{e.errstr}"
ensure
dbh.disconnect if dbh
end
begin
#連線資料庫
dbh=DBI.connect("DBI:Mysql:dbi_test:localhost","root","")
dbh.columns("simple").each do |h|
p h
end
#示範3種事務處理方式
#手動commit
dbh["AutoCommit"]=false
1.upto(10) do |i|
sql = "insert into simple (name, author) VALUES (?, ?)"
dbh.do(sql, "Song #{i}", "#{i}")
end
dbh.commit
#使用transaction方法
dbh.transaction do |dbh|
1.upto(10) do |i|
sql = "insert into simple (name, author) VALUES (?, ?)"
dbh.do(sql, "Song #{i}", "#{i}")
end
end
#使用SQL語句
dbh.do("SET AUTOCOMMIT=0")
dbh.do("BEGIN")
dbh["AutoCommit"]=false
dbh.do("UPDATE simple set name='test' where id='1'")
dbh.do("COMMIT")
#查詢
sth=dbh.execute("select count(id) from simple")
puts "bookCount:#{sth.fetch[0]}"
sth.finish
begin
sth=dbh.prepare("select * from simple")
sth.execute
while row=sth.fetch do
p row
end
sth.finish
rescue
end
#上面這段查詢可以改寫為:
#dbh.select_all("select * from simple") do |row|
# p row
#end
#使用工具類輸出xml格式結果集以及測量查詢時間
sql="select * from simple"
mesuretime=DBI::Utils::measure do
sth=dbh.execute(sql)
end
puts "SQL:#{sql}"
puts "Time:#{mesuretime}"
rows=sth.fetch_all
col_names=sth.column_names
sth.finish
puts DBI::Utils::XMLFormatter.table(rows)
dbh.do("delete from simple")
rescue DBI::DatabaseError=>e
puts "error code:#{e.err}"
puts "Error message:#{e.errstr}"
ensure
dbh.disconnect if dbh
end
相關文章
- linux安裝mysql dbiLinuxMySql
- Centos安裝rubyCentOS
- perl DBI、DBD-mysql、DBD-Oracle安裝MySqlOracle
- ruby jekyll gem 安裝
- Jforum安裝使用指南
- 菜鳥安裝DBI DBD
- ruby安裝及升級
- Centos安裝ruby--jekyllCentOS
- Ruby----RMagick安裝報錯
- 基於oracle linux的 DBI/DBD 標準化安裝OracleLinux
- SVN的安裝及使用指南
- MPlayer安裝和使用指南(轉)
- ruby2.2安裝錯誤一則
- jekyll安裝以及ruby gem映象加速(windows)Windows
- 在Ubuntu 15.04中安裝Ruby on RailsUbuntuAI
- 記錄更新rbenv 和 ruby-build安裝2.3的ruby注意細節UI
- Nginx與Ruby 第二種方法的安裝Nginx
- Nginx與Ruby 第一種方法的安裝Nginx
- rbenv安裝ruby2.3.0線上安裝不上。老子出絕招了(更新)
- Jenkins 使用指南 之 服務安裝篇Jenkins
- perl dbi oracleOracle
- 樹莓派無法升級Ruby或安裝Jekyll樹莓派
- Windows上成功安裝Ruby-1.9.3 gem mysql2WindowsMySql
- A Short Guide to DBIGUIIDE
- 【原創】NOSQL系列-Redis精簡版安裝與Ruby測試SQLRedis
- iOS 9 匯入類庫全面詳盡過程(Ruby安裝->CocoaPods安裝->匯入類庫)iOS
- DBI模組方法簡介(轉)
- perl DBI 學習總結
- Python 裝飾器使用指南Python
- iOS - rvm、Ruby環境CocoaPods安裝使用及相關錯誤處理iOS
- 用rbenv給整個系統安裝ruby(所有使用者都可用)
- [Ruby]format xml with RubyORMXML
- autoit au3 IT管理員使用指南(一)基礎安裝、測試、編譯編譯
- DBI@引數資料型別資料型別
- Vue框架TypeScript裝飾器使用指南Vue框架TypeScript
- DBI 資料庫模組剖析:Perl DBI 資料庫通訊模組規範,工作原理和例項資料庫
- 使用ruby過程中遇到安裝gem失敗的一些通用解決方案
- 《CiscoASA裝置使用指南》一1.4 總結