`

BLOB字段操作

 
阅读更多
置为空或NULL
update blob_test set b_content = null;
update blob_test set b_content = EMPTY_BLOB();

判断内容不为空
select * from blob_test where dbms_lob.getlength(b_content) > 0;  
select * from blob_test where dbms_lob.getchunksize(b_content) > 0;

判断为null
select * from blob_test where b_content is null;

判断为空
select * from blob_test where dbms_lob.getlength(b_content) = 0;

根据目前项目的特点,有一个第三方厂家写入的一个表,记录图片信息,原来使用线程导出后,清空blob字段,现在完全改写为数据库自身实现。这样更高效
例子:之后再用job调用存储过程
CREATE OR REPLACE PROCEDURE GET_PIC_BLOB(pk_id number) IS
  l_file         UTL_FILE.FILE_TYPE;
  l_buffer       RAW(32767);
  l_amount       BINARY_INTEGER := 32767;
  l_pos          INTEGER := 1;
  in_front_blob  BLOB;
  in_back_blob   BLOB;
  out_front_blob BLOB;
  out_back_blob  BLOB;
  l_blob_len     INTEGER;

BEGIN
  select t.in_front_pic, t.in_back_pic into in_front_blob,in_back_blob
    from car_pic t
   where (dbms_lob.getlength(in_front_pic) > 0 and
         dbms_lob.getlength(in_back_pic) > 0) and
          id = pk_id;
   begin
  l_blob_len := DBMS_LOB.GETLENGTH(in_front_blob);
  l_file     := UTL_FILE.FOPEN('TEST1',
                               pk_id || '_in_front' || '.jpg',
                               'WB',
                               32767);
  WHILE l_pos < l_blob_len LOOP
    DBMS_LOB.READ(in_front_blob, l_amount, l_pos, l_buffer);
    UTL_FILE.PUT_RAW(l_file, l_buffer, TRUE);
    l_pos := l_pos + l_amount;
  END LOOP;
  UTL_FILE.FCLOSE(l_file);

  l_pos :=1;
EXCEPTION

  --WHEN NO_DATA_FOUND THEN
  --DBMS_OUTPUT.put_line('no data : ' || i_xh);
  WHEN OTHERS THEN
    IF UTL_FILE.IS_OPEN(l_file) THEN
      UTL_FILE.FCLOSE(l_file);
      RAISE;
    END IF;
    end;
   
       begin
  l_blob_len := DBMS_LOB.GETLENGTH(in_back_blob);
  l_file     := UTL_FILE.FOPEN('TEST1',
                               pk_id || '_in_back' || '.jpg',
                               'WB',
                               32767);
  WHILE l_pos < l_blob_len LOOP
    DBMS_LOB.READ(in_back_blob, l_amount, l_pos, l_buffer);
    UTL_FILE.PUT_RAW(l_file, l_buffer, TRUE);
    l_pos := l_pos + l_amount;
  END LOOP;
  UTL_FILE.FCLOSE(l_file);
  l_pos := 1;

EXCEPTION

  --WHEN NO_DATA_FOUND THEN
  --DBMS_OUTPUT.put_line('no data : ' || i_xh);
  WHEN OTHERS THEN
    IF UTL_FILE.IS_OPEN(l_file) THEN
      UTL_FILE.FCLOSE(l_file);
      RAISE;
    END IF;
    end;
   
END GET_PIC_BLOB;


分享到:
评论

相关推荐

    java,Blob字段操作,将图片或者文件保存到数据库中.zip

    以上就是Java中Blob字段操作的基本流程,通过这些步骤,你可以成功地将图片或文件保存到数据库中,并能从数据库中读取和恢复这些数据。在实际开发中,根据具体需求,可能还需要处理异常、事务管理和资源关闭等问题,...

    【IT十八掌徐培成】Java基础第24天-01.Blob字段操作.zip

    Blob字段操作是数据库编程中的一个重要环节,尤其是在处理大量非结构化数据时。本教程将围绕Java如何与Blob字段进行交互展开,包括插入、查询、更新和删除Blob数据。 首先,理解Blob数据类型。Blob是Java.sql包中的...

    判断blob字段是否为空

    本文将深入探讨如何判断一个BLOB字段是否为空,这是一个在数据库操作中极为实用且关键的技术点。 ### BLOB字段简介 BLOB类型用于存储大量的二进制数据。不同于传统的字符型数据,BLOB可以存储诸如图片、音频文件或...

    Python如何操作Oracle的Blob字段

    Python如何操作Oracle的Blob字段,

    oracle中对blob字段的处理方法

    oracle中对blob字段的处理方法,包括增加,删除,修改,更新等操作。

    java对oracle数据库中blob字段的处理

    Java对Oracle数据库中BLOB字段的处理涉及多个层面,包括读取、写入、更新以及跨数据库操作等。 ### Java处理Oracle BLOB字段的基本方法 #### 1. 读取BLOB字段 在Java中,读取Oracle数据库中的BLOB字段通常通过`...

    C#访问oracle数据库类,带blob字段读写

    写入Blob字段时,先创建`OracleParameter`对象,将其Direction设置为` ParameterDirection.Input `,OracleDbType设置为`OracleDbType.Blob`,然后赋值。以下是一个示例: ```csharp // 读取Blob字段 using ...

    Oracle blob字段上传下载

    本文将详细介绍如何在Oracle数据库中实现Blob字段的上传和下载操作。 #### 二、Blob字段上传 Blob字段的上传通常涉及到以下几个步骤: 1. **创建Blob字段:** 首先需要在数据库表中定义一个Blob类型的字段。 2. **...

    批量导出ORACLE数据库BLOB字段生成图片

    BLOB字段在数据库中以字节流的形式存在,可以进行读写操作。 要实现批量导出BLOB字段生成图片,通常需要以下步骤: 1. **安装Oracle Client**:Oracle Client是与Oracle服务器通信的客户端工具,它提供了与数据库...

    oracle中读取blob字段.doc

    ### Oracle中BLOB字段的读取与操作 #### 一、引言 在数据库系统中,BLOB(Binary Large Object)是一种用于存储大量二进制数据的数据类型,例如图像、音频或视频文件等。在Oracle数据库中,BLOB类型特别适用于处理...

    oracle blob 字段 读写 delphi

    本篇文章将深入探讨如何在Delphi中对Oracle数据库的BLOB字段进行读写操作。 首先,你需要在Delphi项目中引入Oracle数据库访问的相关组件,如DBExpress或ADO。DBExpress是Delphi内置的一个轻量级数据库访问框架,而...

    oracle查询blob字段照片(jpeg) 像素大小sql

    本篇文章将详细介绍如何通过SQL查询语句获取存储在Blob字段中的JPEG格式照片的像素大小。 ### 1. 了解Blob数据类型 在Oracle数据库中,Blob(Binary Large Object)类型用于存储大容量的二进制数据,比如图像、音频...

    计算机软件-商业源码-实例123-存取Blob字段.zip

    压缩包中的"实例123-存取Blob字段"可能包含了上述所有过程的详细实现,包括数据库连接、查询构造、Blob数据的读写等,对于理解Blob字段操作提供了实践性的参考。学习和分析这些源码,可以帮助开发者深入理解如何在...

    ORACLE中BLOB字段导入到SQL SERVER中的IMAGE字段

    1. **数据准备**:确保ORACLE数据库中的BLOB字段包含所需的数据,并且是完整的。可能需要进行数据验证,以确保所有数据都能被正确读取。 2. **数据导出**:使用ORACLE提供的工具,如SQL*Plus或者PL/SQL Developer,...

    批量导出ORACLE数据库BLOB字段生成文件

    本教程将详细讲解如何批量导出Oracle数据库中的BLOB字段并生成文件,适用于需要定期或一次性处理大量图片或其他BLOB数据的场景。 首先,确保你已经在本地安装了Oracle客户端。Oracle客户端提供了SQL*Plus和其他工具...

    Hibernate操作Oarcle中Clob、Blob字段小结

    这篇博客文章“Hibernate操作Oracle中Clob、Blob字段小结”可能会探讨如何在Hibernate中有效地处理这两种类型的数据。 1. **Clob与Blob的理解**: - Clob:Clob是用于存储大量字符数据的类型,例如长篇文章、XML...

    mysql导出工具(blob字段)

    mysql导出工具,可导出无注释插入语句,表中字段有blob类数据,插入语句前还有锁表操作语句,适合多种场景

    Delphi将图片以二进制方式存储在数据库BLOB字段中.rar

    在Delphi中,与数据库交互通常会用到ADO(ActiveX Data Objects)或DBX(Database Express)等组件库,它们支持BLOB字段的读写操作。 在实现这个功能时,TStream类起着核心作用。TStream是一个抽象类,它定义了读写...

Global site tag (gtag.js) - Google Analytics