我遇到了一个问题,我需要将超过4000个字符的字符串转换为XMLTYPE。我尝试使用
XMLTYPE.CREATEXML("MY STRING")
XMLTYPE("MY STRING")
在这两种情况下,我都得到'String literal too long ..'错误。
答案 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 Examples和XMLTYPE 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