【技术总结】关于Oracle大字段的问题及总结

        在日常工作处理中,遇到过一些关于Oracle大字段的问题,每次都是面向百度编程,导致印象不太深刻,特此记录并总结,加深对Oracle大字段的理解。

1.什么是Oracle大字段?

       百度的解释: BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的。其实两个是可以互换的的,或者可以直接用LOB字段代替这两个。
但是为了更好的管理ORACLE数据库,通常像图片、文件、音乐等信息就用BLOB字段来存储,先将文件转为二进制再存储进去。而像文章或者是较长的文字,就用CLOB存储,这样对以后的查询更新存储等操作都提供很大的方便。
BLOB全称为二进制大型对象(Binary Large Object)。它用于存储数据库中的大型二进制对象。可存储的最大大小为4G字节 
CLOB全称为字符大型对象(Character Large Object)。它与LONG数据类型类似,只不过CLOB用于存储数据库中的大型单字节字符数据块,不支持宽度不等的字符集
可存储的最大大小为4G字节,Clob可以存储单字节字符数据,Blob可以存储无结构的二进制数据。

        个人理解:日常项目用途主要是存储报文信息、工作流关联业务信息、二进制文件等,文件存储用得比较少,大多是clob字段。

2.工作中遇到的Oracle大字段相关的问题

2.1.工作流bizcase表中有relatedObject字段为blob类型,怎么输出?

        由于blob存的可能是对象也可能是文件,所以没办法直接输出,使用dbms_lob.instr函数也输出不了,只能使用java程序输出;
用hibernate的查询方法查出bizcase对象之后,用blob接收,然后用如下方法读出:
InputStream inputStream = blob.getBinaryStream();
ObjectInputStream ois = new ObjectInputStream(inputStream);
HashMap amap = (HashMap) ois.readObject();
System.out.println("amap:"+amap);

2.2.财务公司承兑的票据贴现后不在系统中做票据解付,票据结清了,页面上查不到结清通知报文(043),也没有票据状态通知报文(040),怎么在数据库查询票据关联报文信息?

        根据edc_bill.billid=edc_txdetail.billid,edc_txdetail.txdetailid=edc_message.txdetailid查询不到信息。

        票据结清通知报文(043)可能会包含多张结清票据,在保存数据时也未与edc_bill表进行关联,所以页面无法查询到报文信息,需要直接查询edc_message表,查询sql:

SELECT * FROM edc_message t WHERE t.msgtype='043' 
--AND to_char(t.createtime,'yyyy-MM-dd')='2023-02-28'
AND dbms_lob.instr(t.content ,'190752100008420221020369623960')>0;

2.3.新网银应用中心中有配置项需批量修改,配置信息保存在config_detail表的大字段中,怎么用sql查询信息并进行修改?

查询sql:

select * from config_detail t where t.pid in (select id from config where app_no='GDPS' and module_code='01') and dbms_lob.instr(t.row_value ,'907521000017')>0;

更新sql:

update config_detail t set t.row_value = replace(t.row_value,'907521000017','102521003500') 
where t.pid in (select id from config where app_no='GDPS' and module_code='01') and dbms_lob.instr(t.row_value ,'907521000017')>0;

2.4.oracle表字段使用varchar2类型时字段超长无法存储,修改字段类型为clob时数据库报错,是什么原因?

varchar2类型不可以直接改成clob,需要先删除对应字段,再添加类型为clob的同名字段;
原因:Oracle不允许将字段类型修改为:object、REF、nested table、varchar、clob、blob。

2.5.待补充

        遇到的Oracle大字段相关的问题不只这些,还需要更细致的收集及整理。

3.Oracle大字段处理函数及用法

        从上述问题描述中,用得最多的函数是dbms_lob.instr,还有其它函数也可能会用到,具体可查询

DBMS_LOB - DBMS_LOB 概述 - 《OceanBase v3.1.1 官方教程》 - 书栈网 · BookStack

在下面只列出部分常用函数(子程序)。

3.1.dbms_lob.getlength

  GETLENGTH 函数用于获取指定 LOB 的长度。返回的长度以字节或字符为单位。

长度计数中还包括 LOB 中由先前的 WRITE 等操作产生的 0 字节或空格。空的内部 LOB 的长度为 0。

示例:

select dbms_lob.getlength(t.relatedobject) from bizcase t where t.caseid=8967781;

输出:13814

3.2.dbms_lob.read

        可以读取大字段中的信息,但是似乎并不能实现查看功能,示例:

DECLARE

var_clob BLOB;
var_buff VARCHAR(2);
var_len NUMBER(4);
var_start NUMBER(4);

BEGIN

--SELECT RESUME INTO var_clob FROM TLOB WHERE NO = 1;
select t.relatedobject INTO var_clob from bizcase t where t.caseid=8967781;
var_len := 100;--DBMS_LOB.GETLENGTH(varc);
var_start := 1;
DBMS_LOB.READ(var_clob, var_len, var_start, var_buff);
DBMS_OUTPUT.PUT_LINE('RETURN: '||var_buff);

END;

输出

RETURN: ACED0005737200116A6176612E7574696C2E486173684D61700507DAC1C31660D103000246000A6C6F6164466163746F724900097468726573686F6C6478703F4000000000000C7708000000100000000374000A627573696E6573734E6F74000F434432 

3.3.dbms_lob.substr

        截取大字段输出,但是并不能按正常的字符输出。

示例:

select dbms_lob.substr(t.relatedobject,100) from bizcase t where t.caseid=8967781;  

输出:ACED0005737200116A6176612E7574696C2E486173684D61700507DAC1C31660D103000246000A6C6F6164466163746F724900097468726573686F6C6478703F4000000000000C7708000000100000000374000A627573696E6573734E6F74000F434432

 

  • 26
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Oracle是一种基于关系数据库管理系统的软件,广泛用于各种企业级应用程序中。以下是一些常见的Oracle知识点: 1.关系数据库:Oracle是一种关系型数据库管理系统,它使用表结构来存储和组织数据。每个表包含行和列,行表示记录,列表示数据字段。 2.SQL语言:Oracle使用结构化查询语言(SQL),它是一种用于管理和操作数据库的标准语言。使用SQL,可以通过查询、插入、更新和删除实现对数据的操作。 3.索引和约束:为了提高查询性能和数据完整性,Oracle支持创建索引和约束。索引可以加快数据查询的速度,约束可以限制表中数据的有效性。 4.透明数据加密:为了保护数据的安全性,Oracle提供了透明数据加密功能。通过对数据库进行加密,可以确保数据在传输和存储过程中的安全性。 5.备份和恢复:为了防止数据丢失和系统故障,Oracle提供了备份和恢复功能。可以通过数据库备份来保存数据,并在需要时恢复到先前的状态。 6.并发控制:Oracle使用并发控制机制来处理多个用户同时访问数据库的场景。通过锁定机制和事务管理,可以确保数据的一致性和完整性。 7.故障排除和性能优化:在遇到数据库故障或性能问题时,需要进行故障排除和性能优化。Oracle提供了一系列工具和技术来诊断和解决这些问题。 8.数据库安全:Oracle提供了各种安全措施来保护数据库的安全性。例如,访问控制、身份验证和审计功能,都可以用于防止未经授权的访问和滥用。 9.高可用性:为了确保系统的可用性,Oracle支持高可用性解决方案,如数据复制、故障切换和负载均衡。这些功能可以在系统故障时自动切换,保证业务的连续性。 总之,Oracle是一个功能强大、可靠稳定的关系型数据库管理系统,具有广泛的应用领域和丰富的功能特性。以上只是其中一些常见的知识点,使用Oracle需要不断学习和掌握更多的知识和技巧。 ### 回答2: 以下是300字中文对Oracle知识点的罗列: 1. 数据库管理系统(DBMS):Oracle是一种关系型数据库管理系统,用于存储和管理大量的结构化数据,支持SQL查询语言。 2. 数据库对象:Oracle数据库中的核心对象包括表、索引、视图、序列、存储过程等,用于组织和操作数据。 3. 数据库表:Oracle中的表是数据的基本存储单位,由列(字段)组成,每个列具有特定的数据类型和约束。 4. SQL语言:Oracle使用SQL(Structured Query Language)语言进行数据操作和查询,包括数据的插入、更新、删除和查询等操作。 5. 数据库事务:Oracle支持事务处理,可以确保数据的一致性和完整性。事务是一系列数据库操作的逻辑单元,要么全部执行,要么全部回滚。 6. 数据库连接与用户管理:Oracle支持多用户环境,每个用户都可以拥有自己的数据库对象和权限。管理员可以管理用户帐户和权限。 7. 数据库备份和恢复:Oracle提供备份和恢复机制,可以定期备份数据库以保护数据安全,并在需要时进行恢复操作。 8. 数据库性能优化:Oracle提供了各种性能优化技术和工具,包括索引、分区、查询优化器等,以提高数据库的查询和操作速度。 9. 数据库安全:Oracle提供了多层次的安全机制,包括用户身份验证、权限控制、数据加密等,以保护数据库中的数据免受未经授权的访问。 10. 高可用性和故障恢复:Oracle支持集群和灾备技术,以确保数据库的高可用性和故障恢复能力,包括故障切换、数据冗余和自动恢复等。 总结:以上是对Oracle的一些核心知识点的简要罗列,涵盖了数据库管理、对象、SQL语言、事务、用户管理、备份恢复、性能优化、安全和高可用性等方面的内容。这些知识点对于理解和使用Oracle数据库至关重要,并帮助提升数据库管理和应用开发的效率和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值