oracle blob数据类型 插入问题

文章介绍了在Oracle数据库中处理Blob类型数据时遇到的问题,首先尝试用UTL_RAW.CAST_TO_RAW函数配合REPLACE函数直接处理,但未成功。接着,作者提供了两种有效解决方案:一是查询Blob字段的最大长度,然后将替换后的数据转换为16进制;二是使用DBMS_LOB.SUBSTR和RAWTOHEX函数进行转换,成功解决了数据转换问题。
摘要由CSDN通过智能技术生成
-- 尝试第一种方法,解决不行,现实无效的十六机制
SELECT
	concat(
		'UTL_RAW.CAST_TO_RAW',
		concat( '(''',  concat(REPLACE ( job_data, 'N', 'XXX' ),''')') ) ) as JOB_DATA 
	FROM
	qrtz_job_details;
-- 	尝试第二种方法,成功
-- 查出blob字段的最大长度,这儿我定义了4000
SELECT LENGTH(job_data) FROM qrtz_job_details;
-- 查之前替换blob类型里面的数据,然后转化成16进制,完美解决
SELECT SCHED_NAME, RAWTOHEX(UTL_RAW.CAST_TO_VARCHAR2(DBMS_LOB.SUBSTR(TO_BLOB(UTL_RAW.CAST_TO_RAW(REPLACE( job_data, 'N', 'XXX' ))), 4000,1))) as job_data 
FROM qrtz_job_details ;

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值