Oracle LOB类型

一、Oracle中的varchar2类型
1.我们在Oracle数据库存储的字符数据一般是用VARCHAR2。VARCHAR2既分PL/SQL Data Types中的变量类型,也分Oracle Database中的字段类型,不同场景的最大长度不同。
2.在Oracle Database中,VARCHAR2 字段类型,最大值为4000;PL/SQL中 VARCHAR2 变量类型,最大字节长度为32767。
3.当VARCHAR2容纳不下我们需要存储的信息时,就出来的Oracle的大数据类型LOB(Large Object,大型对象)。
二、Oarcle中的LOB类型
1.在Oracle中,LOB(Large Object,大型对象)类型的字段现在用得越来越多了。因为这种类型的字段,容量大(最多能容纳4GB的数据),且一个表中可以有多个这种类型的字段,很灵活,适用于数据量非常大的业务领域(如图象、档案等)。
2.LOB类型分为BLOB和CLOB两种:BLOB即二进制大型对象(Binary Large Object),适用于存贮非文本的字节流数据(如程序、图象、影音等)。
3.而CLOB,即字符型大型对象(Character Large Object),则与字符集相关,适于存贮文本型的数据(如历史档案、大部头著作等)。
三、DB中使用CLOB类型字段
(一)创建表(使用sql或者直接在PL/SQL客户端创建),字段类型CLOB

-- Create table
create table TEMP
(
name VARCHAR2(200),
age NUMBER,
temp_clob CLOB
)
tablespace INSIGHTDATA3_TS
pctfree 10
initrans 1
maxtrans 255
storage
(
initial 160K
next 1M
minextents 1
maxextents unlimited
);

(二)增删改查
先看一下使用普通方式操作CLOB类型:

SELECT t.name, t.temp_clob FROM temp t; --普通查询 INSERT INTO temp t VALUES (‘Grand.Jon‘, 22, ‘加入博客园的第一天‘);

查询因为不是varchar2类型,所以普通查询看不到CLOB类型的字段内容,结果如下:

而普通插入操作也会因为Oracle的隐式转换,默认把字符串转换成varchar2类型,一旦字符串内容超过varchar2的最大限度就会报会报ora-01704(字符串太长)错误。
正确操作

--使用PL/SQL语法,采取绑定变量的方式解决,而不是直接拼接SQL
DECLARE
V_LANG CLOB := ‘待插入的海量字符串‘;

V_UPDATE CLOB := ‘更新的海量字符串‘;
BEGIN
INSERT INTO temp t VALUES (‘Grand.Jon‘, 22, V_LANG); --增加

UPDATE temp t SET t.temp_clob = V_UPDATE WHERE rownum = 1; --修改

SELECT t.NAME, dbms_lob.substr(t.temp_clob) FROM TEMP t; --查询  将CLOB转成字符类型

DELETE temp t WHERE rownum = 1; --按列删除 
 
COMMIT;
END;
/

查询结果如下:

对CLOB的操作我们在存储过程中基本上使用 DBMS_LOB包里面的方法。
dbms_lob 方法总结

dbms_lob.open() 打开LOB
dbms_lob.close() 关闭LOB
dbms_lob.append() 将源LOB中的内容追加到目标LOB
dbms_lob.copy() 从源LOB中的一部分或者全部数据复制到目标LOB
dbms_lob.erase() 删除LOB中全部或部分内容
dbms_lob.trim() 将LOB值减少到指定的长度
dbms_lob.read() 从LOB中读取数据
dbms_lob.write() 写入数据
dbms_lob.compare() 比较两个同种数据类型的LOB的部分或全部值是否相同
dbms_lob.getlength() 获取LOB的长度
dbms_lob.fileopen() 打开文件
dbms_lob.fileclose() 关闭文件
dbms_lob.fileexits() 检查文件的存在性
dbms_lob.createtemporary(V_SQL,true) 创建一个临时clob,用来存储拼接的sql
dbms_lob.write(v_SQL,‘写入信息‘) 写入操作
dbms_lob.append(v_SQL,‘,‘) 拼接clob
dbms_lob.substr(v_SQL) 截取clob,不传参数就是全部读取
dbms_lob.freetemporary(v_SQL) 释放clob 

四、在存储过程中使用CLOB类型实例
需求:以开发的存储过程为例,需要循环遍历时间范围拼接sql,将时间日期按列反转(pivot),如果时间太长(1年以上)sql语句(varchar2)就会超出范围报错,这时候就需要使用CLOB来存储拼接的sql。

PROCEDURE P_AND_CPT_RATIOOTH_APP_BAK2_N(
    V_APPIDS IN VARCHAR2,
    V_TYPE IN VARCHAR2,
    V_CHANNEL IN VARCHAR2,
    V_TABLE IN VARCHAR2,
    V_START IN VARCHAR2,
    V_END IN VARCHAR2,
    RESULT OUT mycursor
) IS

    V_SQL CLOB;
    V_SQLWHERE VARCHAR2(32767) default ‘‘;
    V_SQLWHERE_CHANNEL VARCHAR2(32767) default ‘‘;
    V_SQL_DATES CLOB;
    V_Sdate DATE;
    V_Edate DATE;
    V_TABLE_DATE VARCHAR2(50);
    V_TABLE_TYPE VARCHAR2(50);
    V_START_DATE VARCHAR2(50);
    V_END_DATE VARCHAR2(50);
    V_DAY VARCHAR2(50);

BEGIN
    select column_name into V_TABLE_DATE from user_tab_columns where table_name=‘‘||V_TABLE||‘‘ and column_id=1;
    select column_name into V_TABLE_TYPE from user_tab_columns where table_name=‘‘||V_TABLE||‘‘ and column_id=5;

    dbms_lob.createtemporary(V_SQL,true);--创建一个临时lob
    dbms_lob.createtemporary(V_SQL_DATES,true);--创建一个临时lob

    IF V_APPIDS is NOT NULL THEN
        V_SQLWHERE := ‘AND t.appid in (‘||V_APPIDS||‘)‘;
    END IF;

    IF V_CHANNEL IS NOT NULL THEN
        V_SQLWHERE_CHANNEL := ‘AND t.channel = ‘‘‘||V_CHANNEL||‘‘‘‘;
    END IF;

    IF V_TABLE_DATE = ‘MON‘ THEN
        V_START_DATE := SUBSTR(V_START,0,6);
        V_END_DATE := SUBSTR(V_END,0,6);
        v_sdate := to_date(V_START_DATE, ‘yyyymm‘);
        v_edate := to_date(V_END_DATE, ‘yyyymm‘);

        WHILE (v_sdate <= v_edate) LOOP
            dbms_lob.append(v_SQL_DATES,to_char(v_sdate, ‘yyyymm‘));--把临时字符串付给v_str
            IF v_sdate != v_edate THEN
                dbms_lob.append(v_SQL_DATES,‘,‘);--把临时字符串付给v_str
            END IF;
            v_sdate := add_months(v_sdate,1);
       END LOOP;
    ELSE --周和日 类型 都是 DAY
        v_sdate := to_date(V_START, ‘yyyymmdd‘);
        v_edate := to_date(V_END, ‘yyyymmdd‘);
        V_END_DATE := V_END;

        IF SUBSTR(V_TYPE,0,1)=‘d‘ THEN
            V_START_DATE := to_char(v_sdate, ‘yyyymmdd‘);
            WHILE (v_sdate <= v_edate) LOOP
                dbms_lob.append(v_SQL_DATES,to_char(v_sdate, ‘yyyymmdd‘));--把临时字符串付给v_str
                IF v_sdate != v_edate THEN
                    dbms_lob.append(v_SQL_DATES,‘,‘);--把临时字符串付给v_str
                END IF;
                v_sdate := v_sdate+1;
            END LOOP;        ELSIF SUBSTR(V_TYPE,0,1)=‘w‘ THEN
            select to_char(V_Sdate,‘d‘) INTO V_DAY from dual;
            IF V_DAY!=2 THEN
                V_Sdate:=V_Sdate-7;
            END IF;
            V_START_DATE := to_char(v_sdate, ‘yyyymmdd‘);            WHILE (v_sdate <= v_edate) LOOP
                select to_char(V_Sdate,‘d‘) INTO V_DAY from dual;
                IF V_DAY=2 THEN
                    dbms_lob.append(v_SQL_DATES,to_char(v_sdate, ‘yyyymmdd‘));--把临时字符串付给v_str
                    IF V_Edate-v_sdate >7 THEN
                        dbms_lob.append(v_SQL_DATES,‘,‘);--把临时字符串付给v_str
                    END IF;
                END IF;
                v_sdate := v_sdate+1;
            END LOOP;
        END IF;
    END IF;

    dbms_lob.append(v_sql,‘SELECT * FROM( SELECT *
    FROM ‘||V_TABLE||‘ t
    WHERE
    t.‘||V_TABLE_TYPE||‘ = ‘‘‘||V_TYPE||‘‘‘
    AND t.‘||V_TABLE_DATE||‘ >= ‘‘‘||V_START_DATE||‘‘‘
    AND t.‘||V_TABLE_DATE||‘ <= ‘‘‘||V_END_DATE||‘‘‘
    ‘||V_SQLWHERE||‘
    ‘||V_SQLWHERE_CHANNEL||‘ ) t1

    pivot(sum(MARKETSHARE)
    for ‘||V_TABLE_DATE||‘ in(‘);

    dbms_lob.append(v_sql,v_SQL_DATES);
    dbms_lob.append(v_sql,‘))‘);
    dbms_output.put_line(v_sql);
    OPEN result FOR v_sql; 

    dbms_lob.freetemporary(v_sql);--释放lob
    dbms_lob.freetemporary(v_SQL_DATES);--释放lob
    --dbms_output.put_line(V_SQLDATE);

    -- dbms_output.put_line(v_SQL_DATES);

    --记录操作日志及错误日志
END;

注意:CLOB 类型判断null或空:dbms_lob.getlength(数据库字段) <=0

转自:https://www.cnblogs.com/xwb583312435/p/9052323.htmlhttps://www.cnblogs.com/happinessqi/p/3349661.html

原文地址:https://www.cnblogs.com/shujk/p/12595935.html

时间: 2024-08-03 06:41:03

Oracle LOB类型的相关文章

LOB类型的学习、总结

LOB相关的概念 LOB类型: 将信息文件(十进制.二进制).图像甚至音频信息采用数据库作为保存载体时,就需要使用lob类型数据. 有两种Lob,Internal Lob和External Lob.Internal Lob是指Lob数据存储在Oracle数据文件里,External Lob是指Lob数据存储在数据库外部的操作系统中. CLOB:????????存储大量.单字节.字符数据,存储在内部表空间,用于存储字符串类型的Lob,如文本和XML文件等,字符串已数据库字符集编码. NLOB:??

Oracle LOB

Oracle .NET Framework 数据提供程序包括 OracleLob 类,该类用于使用 Oracle LOB 数据类型. OracleLob 可能是下列 OracleType 数据类型之一: 数据类型 描述 Blob 包含二进制数据的 Oracle BLOB 数据类型,其最大大小为 4 GB.此数据类型映射到 Byte 类型的 Array. Clob 包含字符数据的 Oracle CLOB 数据类型,根据服务器的默认字符集,其最大大小为 4 GB.此数据类型映射到 String. N

db2和oracle字段类型对比

在网上找到一片关于oracle与DB2数据类型的比较,特记下来. Oracle DB2/400 Oracle数据类型 注意事项 DB2 UDB数据类型 注意事项 DATE DATETIMETIMESTAMP l 如果只使用MM/DD/YYY,那么使用DATE类型.l 如果只使用HH:MM:SS, 那么使用TIME类型.l 如果要使用日期和时间,则使用时间戳类型(TIMESTAMP)l 能使用Oracle中的TO_CHAR()函数来取DATE的字串来分别和DB2/400的DATE.TIME相匹配.

Oracle数据库类型总结

RACLE基本数据类型(亦叫内置数据类型 built-in datatypes)可以按类型分为:字符串类型.数字类型.日期类型.LOB类型.LONG RAW& RAW类型.ROWID & UROWID类型.一 字符串类型CHAR类型 CHAR(size [BYTE | CHAR]) CHAR类型,定长字符串,会用空格填充来达到其最大长度.非NULL的CHAR(12)总是包含12字节信息.CHAR字段最多可以存储2,000字节的信息.如果创建表时,不指定CHAR长度,则默认为1.另外你可以指

oracle lob 简单介绍

何为LOB? lob为oracle数据库的一个大对象数据类型,可以存储超过4000bytes的字符串,二进制数据,OS文件等大对象信息.最大可存储的容量根oracle的版本和oracle 块大小有关. 有那几种可供选择的LOB类型? 目前ORACLE提供了CLOB,NCLOB,BLOB,BFILE共四种LOB类型,CLOB,NLOB为大字符串类型,NLOB为多语言集字符类型,类似于NVARCHAR类型,用他们代替以前的LONG类型;BLOG为大二进制类型,用来代替以前的LONG RAW类型;BF

[下载]Oracle LOB字段编辑工具

OraLobEditor 是Oracle LOB (CLOB, BLOB) 字段编辑工具. 查看.编辑LOB (CLOB, BLOB)字段(plain text, RTF, image, hex, html, xml). 支持图片格式(JPEG, GIF, BMP, PNG, TIFF).在十六进制方式中编辑 LOB (CLOB, BLOB) 字段. 查看.在文本编辑器中编辑长字符串(Char, Varchar2)字段. 在十六进制方式中编辑字符串(Char,Varchar2)字段. 下载地址:

Oracle number类型查询精度丢失的解决方法

Oracle number类型查询时,有时候会遇到精度丢失的问题,下面为您介绍了一个解决Oracle number类型查询精度丢失的方法,供您参考. 一.Oracle number类型查询需求中要求查到一个字段的值然后保持小数点后2位//如果采用如下方法从ResultSet得到一个数字,而这个数字大于40000,则得到的数据将不准确 floatzcxxhj+=rss.getFloat(3); //而如果采用double就没有问题 doublezcxxhj+=rss.getDouble(3); /

lob类型数据处理 java.lang.IllegalStateException: No LobHandler found for configuration

1 .MySQL处理数据库中lob类型数据,如longblob类型: 2.实体类定义: private byte[] clientFile; 3.映射文件定义: <property name="clientFile" type="org.springframework.orm.hibernate3.support.BlobByteArrayType">      <column name="client_file"/> &

oracle 自定义类型 type / create type

一:Oracle中的类型有很多种,主要可以分为以下几类: 1.字符串类型.如:char.nchar.varchar2.nvarchar2. 2.数值类型.如:int.number(p,s).integer.smallint. 3.日期类型.如:date.interval.timestamp. 4.PL/SQL类型.如:pls_integer.binary_integer.binary_double(10g).binary_float(10g).boolean.plsql类型是不能在sql环境中使