什么是XMLTABLE

San*_*kur 3 oracle oracle10g

  1. 什么是XMLTABLE.

  2. 请告诉我创建XMLTABLE的语法

  3. 用于从XMLTABLE获取记录的示例查询.

  4. 在创建XMLTABLE之前是否需要任何数据库级先决条件.

And*_*ell 7

函数XMLTABLE用于将xml对象转换为单独的字段.但是您可能希望构建一个包含xml内容的表,这是不同的.

您可以使用包含xml内容的额外列创建表

CREATE TABLE mytable (my_id NUMBER PRIMARY KEY, my_xml XMLType);
Run Code Online (Sandbox Code Playgroud)

然后在查询中使用xml内容.

INSERT INTO mytable VALUES (1,xmltype('<myxml id="D45"/>'));

SELECT my_id
      ,my_xml.extract('/myxml@id').getstringval()
from mytable
Run Code Online (Sandbox Code Playgroud)

成品.

好的回复第二条评论:

所以你确实想要使用XMLTABLE函数,你的错误表明你根本没有得到文件.所以你需要制作你的网址才能正确加载它.我用嵌入式xml构建的测试用例是:

 1  SELECT seq
 2        , id
 3        , content
 4  FROM XMLTABLE('/xml/myrec'
 5        PASSING XMLType('<xml>'
 6                      ||'<myrec id="D12"><content>hello1</content></myrec>'
 7                      ||'<myrec id="D13"><content>hello2</content></myrec>
 8                      ||</xml>')
 9        COLUMNS   seq FOR ORDINALITY
10                , id VARCHAR2(100) PATH '@id'
11                , content VARCHAR2(100) PATH 'content'
12*      ) AS my_table
Run Code Online (Sandbox Code Playgroud)

输出是:

 SEQ ID    CONTENT
---- ----- --------------------
   1 D12   hello1
   2 D13   hello2
Run Code Online (Sandbox Code Playgroud)