ruby DBI安装使用指南

本文涉及的产品
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
RDS AI 助手,专业版
RDS Agent(兼容OpenClaw),2核4GB
简介:
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 
文章转自庄周梦蝶  ,原文发布时间5.17
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
Linux Ruby Windows
|
域名解析 Linux Shell
在 CentOS 8 上安装 Ruby
Ruby 是当今最流行的语言之一。它有简洁的语法,并且是 Ruby on Rails 框架后面的语言。本文,我们将为大家展示三种在 CentOS 8 上安装 Ruby 的方法。
1606 0
在 CentOS 8 上安装 Ruby
|
关系型数据库 MySQL Unix
Ruby 教程 之 Ruby 数据库访问 - DBI 教程 17
Ruby 数据库访问 - DBI 教程
189 2
|
数据采集 XML 数据格式
Ruby详解及安装流程
Ruby是一种高级编程语言,具有简单易学、灵活多变、优雅美丽的语法特点。它是一种面向对象的编程语言,具有动态类型和解释型语言的特性。在Ruby中,可以使用简单易懂的语法来编写代码,实现各种功能,如Web开发、网络编程、脚本编写、GUI开发等。
629 0
|
Linux Ruby
|
Unix Linux Shell
|
Ubuntu Linux Ruby
|
SQL 数据库 Ruby
Ruby 教程 之 Ruby 数据库访问 - DBI 教程 9
Ruby 数据库访问 - DBI 教程
209 0
|
前端开发 Linux 数据库
前端学 Ruby:安装Ruby、Rails
前端学 Ruby:安装Ruby、Rails
366 0
|
网络安全 数据安全/隐私保护 iOS开发
Mac配置Ruby环境和安装CocoaPods
Mac配置Ruby环境和安装CocoaPods
Mac配置Ruby环境和安装CocoaPods