文档章节

Ruby通过OCI8操作Oracle存储BLOB

乾中
 乾中
发布于 2016/04/26 11:16
字数 329
阅读 116
收藏 2

Oracle中BLOB是用来存储图片、文件等大数据对象的。
本文是一个Ruby读写Oracle的BLOB的例子,通过OCI8操作Oracle的存储过程

1、建表

CREATE TABLE "T_IMAGE" (
"ID" NUMBER(11) GENERATED BY DEFAULT AS IDENTITY NOT NULL ,
"IMG" BLOB NULL 
)


2、写blob的存储过程

create or replace PROCEDURE P_WRITE_IMAGE 
(
  I_PID IN NUMBER ,
  B_IMG IN BLOB
)
AS   
  blob_temp BLOB;
  copy_amount integer;
BEGIN
    insert into T_IMAGE values(I_PID,empty_blob());
    commit;
    select IMG into blob_temp FROM T_IMAGE where id = I_PID FOR UPDATE; 
    copy_amount := dbms_lob.getlength(B_IMG);
    dbms_lob.copy(blob_temp, B_IMG, copy_amount);
    commit;
END P_WRITE_IMAGE;

3、读blob的存储过程

CREATE OR REPLACE PROCEDURE "P_READ_IMAGE"
(
V_IMG_ID IN NUMBER,
CUR_RESULT OUT SYS_REFCURSOR
)
AS
BEGIN
    OPEN CUR_RESULT FOR
    SELECT ID,IMG
    FROM T_IMAGE
    WHERE ID=V_IMG_ID ;
END;

4、ruby写图片操作

require 'oci8'
h_conn = OCI8.new(DB_USER, DB_PASSWORD, DB_SERVER)
s_photo_full_path = "~/111.jpg"
begin
  cursor = h_conn.parse('begin P_WRITE_IMAGE (
      :photo_id,
      :photo
  ); end;')
  lob_photo = OCI8::BLOB.new(h_conn, File.read(s_photo_full_path, :mode => 'rb'))
  cursor.bind_param(':photo_id', nil, Fixnum)
  cursor.bind_param(':photo', lob_photo )
  cursor.exec()
rescue OCIError
  puts '-'*80
  puts "Code: " + $!.code.to_s
  puts "Desc: " + $!.message
  puts '-'*80
end

5、ruby读图片操作

require 'oci8'
h_conn = OCI8.new(DB_USER, DB_PASSWORD, DB_SERVER)
s_photo_target_path = "~/222.jpg"
photo_id = 1
begin
    cursor = h_conn.parse('begin P_READ_IMAGE(
          :img_id,
          :list
      ); end;')
    cursor.bind_param(':img_id', photo_id)
    cursor.bind_param(':list', nil, OCI8::Cursor)
    cursor.exec()
    ret_cursor = cursor[':list']
    puts ret_cursor.getColNames.join(",")
    while row = ret_cursor.fetch()
        puts row[0]
        File.open(s_photo_target_path, 'wb') do |f|
            f.write(row[1].read)
        end
        break;
    end
rescue OCIError
    puts '-'*80
    puts "Code: " + $!.code.to_s
    puts "Desc: " + $!.message
    puts '-'*80
end



参考教程

http://www.oracle.com/technetwork/cn/tutorials/rubyrails-095981-zhs.html

http://ruby-oci8.rubyforge.org/en/FAQ.html


© 著作权归作者所有

乾中
粉丝 2
博文 4
码字总数 3532
作品 0
佛山
技术主管
私信 提问
Kali安装OCI8 for metasploit Oracle login

ps:安装了好久,最好才发现很简单,步骤记录下吧 遇到oracle爆破登录的时候OCI8报错,如下图 安装oracle 前面关于oracle client的安装就看官方文档吧 http://dev.metasploit.com/redmine/pr...

Cnlouds
2013/11/25
1K
0
ruby-oci8

ruby-oci8 是 Ruby 使用 Oracle 的 OCI8 接口连接 Oracle 数据库的接口。支持包括 Oracle8, Oracle8i, Oracle9i, Oracle10g 和 Oracle Instant Client 等. Windows 下的安装方法:http://ru......

匿名
2009/01/02
1K
0
没有定义 ORACLE_HOME,phpinfo 却显示了 ORACLE_HOME

php 7.2.1 编译时使能了 oci8(--with-oci8=shared,instantclient,/usr/lib/oracle/12.2/client64/lib), 然后没有在任何地方定义 ORACLE_HOME。 为什么 phpinfo 的页面显示:ORACLE_HOME /...

LootanHu
2018/02/02
94
0
php和apache升级后连接不上oracle

原来是: apache_2.0.55-win32-x86-no_ssl.msi PHP5.2.4.rar instantclient10_1 Oracle Run-time Client Library Version 10.2.0.5.0 运行正常的…… 然后升级到 apache-2.4.7-win32-VC9.zip......

流海
2013/12/18
343
1
数据库模板库--OTL

OTL 是 Oracle, Odbc and DB2-CLI Template Library 的缩写,是一个C++编译中操控关系数据库的模板库,它目前几乎支持所有的当前各种主流数据库,例如Oracle, MS SQL Server, Sybase, Inform...

匿名
2012/05/12
6.7K
1

没有更多内容

加载失败,请刷新页面

加载更多

非webpack require.js + vue + vueRouter + iView 实现按需加载

适合一个人开发的时候,在整个php框架下,又想单页,又可以直接后端assign变量穿透到模板。又不想写接口搞前后分离脚手架一大堆npm 包, 在php模板下 引入require.js <!DOCTYPE html><html...

一箭落旄头
10分钟前
2
0
新特性解读 | MySQL 8.0 窗口函数详解

原创作者: 杨涛涛 背景 一直以来,MySQL 只有针对聚合函数的汇总类功能,比如MAX, AVG 等,没有从 SQL 层针对聚合类每组展开处理的功能。不过 MySQL 开放了 UDF 接口,可以用 C 来自己写UDF...

爱可生
16分钟前
0
0
23.5 jumpserver介绍

23.5 jumpserver介绍 开源堡垒机jumpserver介绍: 官网www.jumpserver.org Jumpserver是一款使用Python, Django开发的开源跳板机系统, 助力互联网企业高效 用户、资产、权限、审计 管理 Auth...

oschina130111
22分钟前
2
0
Spring Cloud 入门教程(七): 消息总线(Spring Cloud Bus)(Greenwich.RELEASE)

参考网址:https://blog.csdn.net/forezp/article/details/81041062,由于此文中作者基于git和rabbitMq,为了适应内网我改造为基于mysql和kafka 一、准备工作 1、安装kafka 参考这个:kafka...

pipi1919
23分钟前
1
0
用人工智能改变企业与客户的连接方式

  随着以AI人工智能技术为主的新一代信息技术的快速商业化落地,我国的数字经济正高歌猛进。2017年我国数字经济对GDP的贡献率为55%,接近甚至超越了某些发达国家水平,2018年我国数字经济规...

琴殇的
27分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部