gpt4 book ai didi

string - 如何将大型 XML 字符串插入 Oracle 表中?

转载 作者:行者123 更新时间:2023-12-01 16:20:33 42 4
gpt4 key购买 nike

我想将一个大的 XML 字符串插入到我的表中。我的表是 test_id(xml_column XMLType)。

当我插入值时,它返回“字符串文字太长”错误。我上网查了一下,大家都说把数据类型改成CLOB。但我想存储相同的数据类型(XMLType)。

有没有可能做到这一点。谁能帮我解决这个问题。

这是我的代码:

insert into TEST_ID(xml_column) values('<root>
<DatabaseLog>
<DatabaseLogID>1</DatabaseLogID>
<PostTime>2012-03-14T13:14:18.803</PostTime>
...
<object>StoreSurveySchemaCollection</object>
</DatabaseLog>
</root>');

错误代码是:

PLS-00172: string literal too long

感谢您的建议。

最佳答案

从 Oracle 11g 开始,XMLTYPE 值的最大大小为 2G/4G,具体取决于您的字符集。这与 CLOB 类型相同。但是,这里的问题不在于内容对于XMLTYPE来说太大。您在查询中使用的 litteral VARCHAR 太长了。错误消息非常清楚地说明了这一点:

PLS-00172: string literal too long

一种解决方案(尽管不是一个非常优雅的解决方案)是将字符串分成几部分,分配给 CLOB 变量:

xmlDoc CLOB := 'xml chunk #1';
...
xmlDoc := xmlDoc || 'xml chunk #2';
xmlDoc := xmlDoc || 'xml chunk #3';

...
insert into TEST_ID(xml_column) values(xmlDoc);

关于string - 如何将大型 XML 字符串插入 Oracle 表中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27601085/

42 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com