首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle XMLTable和Create Table As语法错误

Oracle XMLTable和Create Table As语法错误
EN

Stack Overflow用户
提问于 2021-03-10 05:02:56
回答 1查看 60关注 0票数 0

我尝试从XMLTable类型执行create table as,以便将具有逗号分隔值的列拆分为多个行,但得到语法不正确的错误。

我的语句看起来像这样

代码语言:javascript
复制
create table XX as (
select * from yy, xmltable(('"' || replace(csv_separated_list, ',', '","') || '"'))
)

如果我运行select子查询,它会按预期工作...因此,看起来它与包装它的create table as语句有关。

EN

回答 1

Stack Overflow用户

发布于 2021-03-10 05:53:06

从虚拟XML中提取的值不是字符串,尽管您的客户端可能会将其显示为字符串。dump()函数将其报告为类型58,which is an opaque type。有一个隐式转换,从它到表列允许的XMLType数据类型;这抛出了一个XML处理错误,因为该值本身不是有效的XML值。

您可以将其转换为字符串类型:

代码语言:javascript
复制
create table XX as
select yy.*, cast(x.column_value as varchar2(30)) as value
from yy
cross join xmltable(('"' || replace(csv_separated_list, ',', '","') || '"')) x

或者在xmltable中指定数据类型:

代码语言:javascript
复制
create table XX as
select yy.*, x.value
from yy
cross join xmltable(('"' || replace(csv_separated_list, ',', '","') || '"')
  columns value varchar2(30) path '.') x

db<>fiddle

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66554745

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档