ruby连接数据库

 
1.使用mysql驱动连接数据库
require 'mysql'

mysql = Mysql.init()
mysql.connect('localhost', 'root', 'root')
mysql.select_db('test')

results = mysql.query("select * from test")
results.each do |row|
puts row[0]
end

mysql.close

2.DBI连接数据库
这种方式,刚开始遇到无法加载驱动的问题:
代码:
#require 'rubygems'
#gem 'mysql'
#gem 'dbi'
require 'dbi'

con = DBI.connect("dbi:Mysql:test")
result = con.execute("select count(id) from test")
puts result.fetch[0]
con.disconnect

错误:
in `load_driver': Could not load driver (no such file to load -- DBD/mysql/mysql) (DBI::InterfaceError)
或者
in `load_driver': Unable to load driver

前一种我用下面的方法解决的,代码:
require 'rubygems'
gem 'mysql'
gem 'dbi'
require 'dbi'

con = DBI.connect("dbi:Mysql:test")
result = con.execute("select count(id) from test")
puts result.fetch[0]
con.disconnect

后一种我手动重新安装了一次DBI,安装完后目录(D:\ruby\lib\ruby\site_ruby\1.8\DBD)下多了,mysql文件夹和Mysql.rb文件,mysql文件夹下有database.rb,driver.rb,statement.rb三个文件
同样用上面的代码连接数据库,问题解决
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值