- 論壇徽章:
- 0
|
使用Ruby DBI模塊
原本的DBI模塊的安裝教程:
1.安裝
首先,我是使用mysql進(jìn)行測試的,你的機(jī)器上需要安裝mysql數(shù)據(jù)庫。
然后執(zhí)行:
gem install mysql
到rubyforge下載ruby-DBI,解壓后cd到目錄運(yùn)行如下命令:
ruby setup.rb config --with=dbi,dbd_mysql
ruby setup.rb setup
ruby setup.rb install
完整的setup命令參數(shù)參考DBI的doc
2.完整例子
DBI是一類似于ODBC的開發(fā)式的統(tǒng)一的數(shù)據(jù)庫編程接口,結(jié)構(gòu)層次上可以分為兩層:
1.Database Interface——數(shù)據(jù)庫接口層,與數(shù)據(jù)庫無關(guān),提供與數(shù)據(jù)庫無關(guān)的標(biāo)準(zhǔn)接口
2.Database Driver——數(shù)據(jù)庫驅(qū)動(dòng),與數(shù)據(jù)庫相關(guān)
DBI也是很簡單易用的,一個(gè)完整的使用例子,對于初學(xué)者可能有點(diǎn)幫助:- require 'dbi'
- begin
- #連接數(shù)據(jù)庫
- dbh=DBI.connect("DBI:Mysql:dbi_test:localhost","root","")
-
- dbh.columns("simple").each do |h|
- p h
- end
- #示范3種事務(wù)處理方式
- #手動(dòng)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
復(fù)制代碼 #使用工具類輸出xml格式結(jié)果集以及測量查詢時(shí)間- 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
復(fù)制代碼 出現(xiàn)問題:
但是每次我執(zhí)行第一步的時(shí)候就會(huì)出現(xiàn) config: unknown option --with=dbi,dbd_mysql Try 'ruby setup.rb --help' for detailed usage.
原因分析:
這是由于dbi版本問題造成的。
因此新版本的安裝方式如下:
一般方法是:下載dbi(tar.gz或zip格式),CMD下切換到解壓的目錄,使用以下命令:- ruby setup.rb config (或ruby setup.rb config --with=dbi,dbd_mysql)
- ruby setup.rb setup
- ruby setup.rb install
復(fù)制代碼 報(bào)錯(cuò):
ir- b(main):001:0> require 'dbi'
- LoadError: no such file to load -- deprecated
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from C:/MyProgramFiles/Ruby192/lib/ruby/site_ruby/1.9.1/dbi.rb:48:in `<t
- op (required)>'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from (irb):1
- from C:/MyProgramFiles/Ruby192/bin/irb:12:in `<main>'
- irb(main):002:0>
復(fù)制代碼 這個(gè)問題比較簡單,只要安裝一個(gè)deprecated包,于是我下載了deprecated-3.0.0.gem,安裝之后還是報(bào)錯(cuò)。- irb(main):001:0> require 'dbi'
- NoMethodError: undefined method `deprecate' for DBI::Date:Class
- from C:/MyProgramFiles/Ruby192/lib/ruby/site_ruby/1.9.1/dbi/utils/date.r
- b:57:in `<class:Date>'
- from C:/MyProgramFiles/Ruby192/lib/ruby/site_ruby/1.9.1/dbi/utils/date.r
- b:7:in `<module:DBI>'
- from C:/MyProgramFiles/Ruby192/lib/ruby/site_ruby/1.9.1/dbi/utils/date.r
- b:1:in `<top (required)>'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from C:/MyProgramFiles/Ruby192/lib/ruby/site_ruby/1.9.1/dbi/utils.rb:56:
- in `<top (required)>'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from C:/MyProgramFiles/Ruby192/lib/ruby/site_ruby/1.9.1/dbi.rb:50:in `<t
- op (required)>'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from (irb):1
- from C:/MyProgramFiles/Ruby192/bin/irb:12:in `<main>'
- irb(main):002:0>
復(fù)制代碼 再次Google,居然是deprecated-3.0.0.gem太新了!換成deprecated-2.0.1.gem就可以了。- irb(main):001:0> require 'dbi'
- => true
- irb(main):002:0>
復(fù)制代碼 這個(gè)問題還是比較容易解決的,不過要是出現(xiàn)如下問題就不好解決了:- <internal:lib/rubygems/custom_require>:29:in `require': no such file to load -- parsedate (LoadError)
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from c:/Program Files (x86)/RailsInstaller/Ruby1.9.2/lib/ruby/site_ruby/1.9.1/dbi/sql.rb:9:in `<module:DBI>'
- from c:/Program Files (x86)/RailsInstaller/Ruby1.9.2/lib/ruby/site_ruby/1.9.1/dbi/sql.rb:7:in `<top (required)>'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from c:/Program Files (x86)/RailsInstaller/Ruby1.9.2/lib/ruby/site_ruby/1.9.1/dbi.rb:37:in `<top (required)>'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from <internal:lib/rubygems/custom_require>:29:in `require'
- from E:/Program/Eclipse/RubyTest/dbi.rb:1:in `<main>'
復(fù)制代碼 經(jīng)過查詢之后,才發(fā)現(xiàn)原來parsedate在ruby1.9.2中已經(jīng)被廢除了,現(xiàn)在使用的是date。因此這個(gè)版本問題真的是沒有辦法進(jìn)行解決啦。我現(xiàn)在正在考慮要不要把ruby降級來解決這個(gè)問題。嘗試中,后面如果解決了會(huì)進(jìn)行更新。
|
|