将pl / sql中超过4000个字符的Varchar转换为XMLTYPE

时间:2013-11-25 07:25:15

标签: sql oracle

我遇到了一个问题,我需要将超过4000个字符的字符串转换为XMLTYPE。我尝试使用

XMLTYPE.CREATEXML("MY STRING")
XMLTYPE("MY STRING")

在这两种情况下,我都得到'String literal too long ..'错误。

2 个答案:

答案 0 :(得分:1)

我们只能传递xml格式的数据来创建XMLTYPE实例,并使用CLOB传递字符串值,然后使用EXTRACTVALUE函数来检索数据

DECLARE 
str CLOB;
x XMLTYPE;
y CLOB:='<TEXT>MY STRING</TEXT>';
BEGIN
x:= XMLTYPE.CREATEXML(y);
select to_clob(extractvalue(x,'/TEXT')) into str FROM DUAL;
dbms_output.put_line(str);
END;

请查看链接XMLTYPE ExamplesXMLTYPE Documantation以获取更多实际示例

答案 1 :(得分:0)

如果要选择作为Varchar返回的整个XML类型,可以执行以下操作。在这里,我选择整个xml值。

DECLARE 
str VARCHAR2(4000);
x XMLTYPE;
y CLOB:='<TEXT>MY STRING</TEXT>';
BEGIN
x:= XMLTYPE.CREATEXML(y);
str := x.EXTRACT('/').getstringval();
dbms_output.put_line(str);
END;

输出: <TEXT>MY STRING</TEXT>

您可以深入查看子节点,如下所示。

DECLARE 
str VARCHAR2(4000);
x XMLTYPE;
y CLOB:='<PARENT><TEXT>MY STRING</TEXT></PARENT>';
BEGIN
x:= XMLTYPE.CREATEXML(y);
str := x.EXTRACT('PARENT/TEXT').getstringval();
dbms_output.put_line(str);
END;

输出: <TEXT>MY STRING</TEXT>

最后,如果你只想要你可以做的价值。

DECLARE 
str VARCHAR2(4000);
x XMLTYPE;
y CLOB:='<PARENT><TEXT>MY STRING</TEXT></PARENT>';
BEGIN
x:= XMLTYPE.CREATEXML(y);
str := x.EXTRACT('PARENT/TEXT/text()').getstringval();
dbms_output.put_line(str);
END;

输出: MY STRING