zoukankan      html  css  js  c++  java
  • 使用Ruby DBI模块

    原本的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也是很简单易用的,一个完整的使用例子,对于初学者可能有点帮助:

    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   
    出现问题:
    但是每次我执行第一步的时候就会出现 config: unknown option --with=dbi,dbd_mysql Try 'ruby setup.rb --help' for detailed usage. 
    原因分析:
    这是由于dbi版本问题造成的。
    因此新版本的安装方式如下:

    一般方法是:下载dbitar.gzzip格式),CMD下切换到解压的目录,使用以下命令:

    ruby setup.rb config (或ruby setup.rb config --with=dbi,dbd_mysql

    ruby setup.rb setup

    ruby setup.rb install

    报错

    irb(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>

    这个问题比较简单,只要安装一个deprecated包,于是我下载了deprecated-3.0.0.gem,安装之后还是报错。
    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>

    再次Google,居然是deprecated-3.0.0.gem太新了!换成deprecated-2.0.1.gem就可以了。

    irb(main):001:0> require 'dbi'  
    => true  
    irb(main):002:0> 


    这个问题还是比较容易解决的,不过要是出现如下问题就不好解决了:

    <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>'

    经过查询之后,才发现原来parsedate在ruby1.9.2中已经被废除了,现在使用的是date。因此这个版本问题真的是没有办法进行解决啦。我现在正在考虑要不要把ruby降级来解决这个问题。尝试中,后面如果解决了会进行更新。

  • 相关阅读:
    5月14日 游戏闯关,
    无名管道练习小程序
    关于对进程、线程的返回状态的获取的理解
    C语言中内存分布及程序运行中(BSS段、数据段、代码段、堆栈)
    linux 与会话相关的一些概念、登录过程
    linux进程——fork、vfork 两函数的实现及两者区别
    关于 linux 中init 进程
    linux进程——fork()函数
    linux下 vim多屏幕操作
    linux下进程管理
  • 原文地址:https://www.cnblogs.com/huzhiwei/p/2369789.html
Copyright © 2011-2022 走看看