c# - 替换 PL/SQL 中的特殊 XML 字符

标签 c# sql xml oracle

我正在使用返回特殊字符的 SQL XMLAgg 函数。我需要用“常规”字符替换它们,即替换 &lt;<等..

我试过使用UTL_I18N.UNESCAPE_REFERENCE但我遇到了错误

ORA-22835: Buffer too small for CLOB or BLOC to RAW conversion (actual: 10030, maximum: 4000)

我的查询看起来像:UTL_I18N.UNESCAPE_REFEREENCE(xmlagg(xmlelement(e, comments)).extract('//text()').getclobval))

我该怎么做?

谢谢

最佳答案

像这样以 block 的形式处理 CLOB:

CREATE OR REPLACE FUNCTION UNESCAPE_XML(xml_clob IN CLOB) RETURN CLOB IS
DECLARE

    clob_UNESCAPE CLOB;    
    read_offset INTEGER := 1;
    ClobLen INTEGER;
    amount INTEGER := 3000;

BEGIN

    ClobLen := DBMS_LOB.GETLENGTH(xml_clob);
    DBMS_LOB.CREATETEMPORARY(clob_UNESCAPE, TRUE);
    LOOP
        EXIT WHEN read_offset > ClobLen;
        stringBuffer := UTL_I18N.UNESCAPE_REFEREENCE(DBMS_LOB.SUBSTR(xml_clob , amount, read_offset));
        DBMS_LOB.WRITEAPPEND(clob_UNESCAPE, LENGTH(stringBuffer), stringBuffer);
        read_offset := read_offset + amount;
    END LOOP;

    RETURN clob_UNESCAPE;
END;

关于c# - 替换 PL/SQL 中的特殊 XML 字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53914336/

相关文章:

c# - 应用程序设置与应用程序设置。应用程序设置已过时?

c# - float C#

c# - 在 switch 语句中显示 Console.ReadLine()

mysql 选择从今天到现在的所有内容

sql - View 可以更新/插入/删除吗?如果是,在什么条件下?

mysql - 在 mysql 中,如何只从一个表中获取不链接到具有特定 ID 的另一个表中的任何行的行

c++ - 从 XML 中提取特定数字属性的有效方法

xml - Xquery 中的分组和计数

c# - 什么是 C# 检查的 C++ 等价物

sql - 在 SQL Server 2008 中检查 xml 字段的值