.NET Core NuGet程序包:Oracle.ManagedDataAccess.Core 查询Oracle BLOB字段报错:TTC Error解决方案
报错截图如下:
报错语句如下,其中PHOTO为BLOB字段:
select PHOTO from employee_photo
此类语句在.NET FrameWork下并无异常,但用.NET Core NuGet程序包:Oracle.ManagedDataAccess.Core访问Oracle数据库时爆发:TTC Error 异常
后查找资料,官方并无解决方案,最后在: 找到相关答案
修改后SQL语句如下
WITH
INFO
AS
(length(A.PHOTO) AS FILE_CONTENT_LENGTH, MOD(length(A.PHOTO),2000) AS MOD,CASEWHEN MOD(length(A.PHOTO),2000) > 0 THEN TRUNC((length(A.PHOTO)/2000) + 1)ELSE TRUNC(length(A.PHOTO)/2000)END INTERATION_COUNT,a.PHOTO as FILE_CONTENTFROM employee_photo A ployee_no = '123456'
)
,OFFSETS AS
(SELECT(2000 * (ROWNUM-1)) + 1 AS OFFSET,I.MOD,I.FILE_CONTENT_LENGTH,I.INTERATION_COUNT,i.FILE_CONTENTFROM INFO ICONNECT BY LEVEL <= I.INTERATION_COUNT
)
,RESULT AS
(SELECTDBMS_LOB.SUBSTR(O.FILE_CONTENT, 2000, O.OFFSET) AS CONTENT,O.OFFSET,O.MOD,O.FILE_CONTENT_LENGTH,O.INTERATION_COUNTFROM OFFSETS O
)
SELECT * FROM RESULT R ORDER BY R.OFFSET ASC
查询结果会把BLOB字段拆分为多行,每行2000个字节,程序按字段 OFFSET 顺序拼接起来即可
本文发布于:2024-02-04 05:42:34,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170700310652726.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |