通過(guò)OCI8接口連接Oracle數(shù)據(jù)庫(kù)
連接Oracle數(shù)據(jù)庫(kù)的方法很多,下面為您介紹了一個(gè)通過(guò)OCI8接口連接Oracle數(shù)據(jù)庫(kù)的方法,希望對(duì)您學(xué)習(xí)連接Oracle數(shù)據(jù)庫(kù)方面能有所幫助。
如果你是是有那個(gè)PL/SQL程序的話(huà),就可以順利的執(zhí)行以下的步驟了,因?yàn)閛ci8會(huì)使用tnsname中的配置 通過(guò)PL/SQL訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)
a 使用該命令直接安裝:gem install ruby-oci8
b 下載文件:http://rubyforge.org/projects/ruby-oci8/
B1.下載文件: ruby-oci8-1.0.6-mswin32.rb
下載到本地后通過(guò)命令 執(zhí)行rb文件:ruby ruby-oci8-1.0.6-mswin32.rb
B2. 下載文件:ruby-oci8-1.0.6-x86-mswin32-60.gem
............................... N多安裝方式
***文件如下:
ruby-oci8-1.0.6-mswin.rb 56 KB 1,989 i386 Other
ruby-oci8-1.0.6-x86-mswin32-60.gem 112 KB 780 i386 .gem (RubyGem)
ruby-oci8-1.0.6.gem 116 KB 798 Any .gem (RubyGem)
ruby-oci8-1.0.6.tar.gz
安裝成功后,驗(yàn)證是否連接Oracle數(shù)據(jù)庫(kù)通過(guò),方法如下:
#使用的時(shí)候一定要加載oci8
require 'oci8'
#創(chuàng)建連接
conn = OCI8.new("用戶(hù)名", "密碼","oracle服務(wù)器名稱(chēng)")
a =[]
#執(zhí)行查詢(xún)操作
cursor = conn.exec('select * from 表名') { |r| a<<r; puts r.join('')}
puts r.join('') 主要是輸出樣式的問(wèn)題 可以使用 puts r.to_s
函數(shù)用法如下:
1)OCI8.new
OCI8.new(userid, password, dbname = nil, privilege = nil)
connect to Oracle by userid and password. dbname is the connect string of Net8.
If you need DBA privilege, please set privilege as :SYSDBA or :SYSOPER.
If the Oracle client is 10g or later, you can use "//hostname_or_ip:port_no/oracle_sid" as dbname.
# sqlplus scott/tiger
conn = OCI8.new("scott", "tiger")
# sqlplus scott/tiger@orcl.world
conn = OCI8.new("scott", "tiger", "orcl.world")
# sqlplus 'sys/change_on_install as sysdba'
conn = OCI8.new("sys", "change_on_install", nil, :SYSDBA)
# sqlplus scott/tiger@//oracle_db.example.com/XE
conn = OCI8.new("scott", "tiger", "//oracle_db.example.com/XE")
2)exec
exec(sql, *bindvars)
如果你沒(méi)有配置PL/SQL 沒(méi)有本地的tnsname 后者不想使用本地的TNSname 就可以直自己去定義個(gè)函數(shù):
def open_connection
tnsnames = '(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = somehost.somedomain.com)(PORT = 1521)) (CONNECT_DATA = (SID = some_sid)))'
connection = OCI8.new('your_username', 'your_password', tnsnames)
end
至于open_connection函數(shù)后面是否需要配置參數(shù),看項(xiàng)目需求了。如果你的項(xiàng)目數(shù)據(jù)庫(kù)基本就是那么一個(gè)的話(huà) 就可以直接在里面定義了
當(dāng)然也可以傳參數(shù)
數(shù)據(jù)庫(kù)訪(fǎng)問(wèn)地址變化多的話(huà) 那就是要傳參數(shù)了。。。
【編輯推薦】
使用oracle存儲(chǔ)過(guò)程分頁(yè)的實(shí)例