教你快速实现Ruby操作Oracle数据库

开发 开发工具
我们在这里为大家总结了Ruby操作Oracle数据库的几个操作步骤,Ruby的下载,和安装;下载安装Ruby/OCI8;书写Ruby脚本文件等等。

对于一个编程人员来说,熟练的掌握编程语言操作数据库是一个必要的技能之一。下面我们就为大家介绍有关Ruby操作Oracle数据库的实现方法。#t#

Ruby操作Oracle数据库1.在如下地址下载Ruby:

http://www.ruby-lang.org/zh_CN/downloads/
在这里我们下载Ruby的windows版本:
点击:Ruby 1.8.6 一步安装 连接,下载文件:ruby186-26.exe

Ruby操作Oracle数据库2.安装Ruby

双击ruby186-26.exe运行即可安装Ruby。

Ruby操作Oracle数据库3.下载安装Ruby/OCI8

为了使 Ruby 能够与我们的 Oracle 数据库通信,需要使用 Ruby/OCI8。可从
http://rubyforge.org/projects/ruby-oci8/ 下载文件:

ruby-oci8-1.0.0-mswin32.rb

双击该文件即可完成Ruby/OCI8的安装

Ruby操作Oracle数据库4.书写Ruby脚本文件,完成从文本文件offeridlist.txt中读取商品ID并更改商品状态的任务:

新建一个文本文件,输入如下代码,保存为:update_offer_state.rb

require ’dbi’

i=0
dbh = DBI.connect(’DBI:OCI8:TNSDBNAME’, ’username’, ’password’)
sqlCapitalsUpdate = \"UPDATE product_offer SET state = ? WHERE offer_id in(?) and state=?\"

print \"请输入商品原来状态:\"
old_state=gets
old_state=old_state.chomp; #chomp去除输入行后面的换行

print \"请输入商品目标状态:\"
str_state=gets
str_state=str_state.chomp; #chomp去除输入行后面的换行

puts \"\"

file1 = File.open(’offeridlist.txt’,\"r\")
#str=file.readlines
#puts str
file1.each do |l|
rs = dbh.prepare(’SELECT state FROM product_offer where offer_id=’+l.to_s)
rs.execute
rsRow = rs.fetch
if rsRow.to_s==old_state.to_s then
puts l
i=i+1
dbh.do(sqlCapitalsUpdate,str_state.to_s,l.to_i,old_state.to_s)
end
end
file1.close
if i.to_i!=0 then
puts \"\"
print \"以上\"+i.to_s+\"个商品状态已经由\"+old_state.to_s+\"改为:\"
puts str_state
end

dbh.commit
dbh.disconnect

puts \"\"
print \"请按任意键退出:\"
gets
exit

新建文本文件:offeridlist.txt,在该文件中保存商品ID:

120010020
120010022

将文件offeridlist.txt、update_offer_state.rb保存在同一个目录下

Ruby操作Oracle数据库5.检查Ruby脚本的语法错误

在命令行输入 ruby -cw update_offer_state.rb 完成脚本update_offer_state.rb的语法检查

如果检查语法没有错误,显示如下: [Page]

C:\\>ruby -cw update_offer_state.rb
Syntax OK

Ruby操作Oracle数据库6.运行Ruby脚本:

(1).在命令行输入 ruby update_offer_state.rb 即开始运行 update_offer_state.rb脚本 。

(2).windows环境下,双击文件update_offer_state.rb也可以 开始运行该脚本。

责任编辑:曹凯 来源: svn8.com
相关推荐

2022-01-19 08:33:17

Oracle数据库AutoUpgrad

2009-12-17 13:30:49

Ruby操作Acces

2024-03-07 13:02:57

PythonSQLite数据库

2024-05-08 08:37:44

2011-08-02 17:06:29

Oracle远程数据库创建DB Link

2011-07-05 10:27:06

MySQL数据库检索排序

2011-04-01 14:51:37

Oracle数据库导入导出

2009-03-26 11:42:36

定时备份Oracle

2011-04-01 14:51:37

Oracle数据库导入导出

2009-03-10 09:38:02

oraclepython数据库

2010-05-05 15:45:52

Oracle数据库

2010-04-27 10:39:59

Oracle数据库

2017-10-16 16:43:05

数据库Oracle数据丢失

2010-05-12 17:45:03

MySQL数据库引擎

2023-12-26 07:40:34

2010-08-04 11:18:09

2017-12-26 15:10:30

数据库Oracle操作语句

2011-05-26 14:31:57

Oracle数据库

2010-04-22 16:08:24

Oracle数据库

2010-10-26 16:07:45

连接oracle数据库
点赞
收藏

51CTO技术栈公众号