Oracle XMLTable

General Information
Library Note Morgan's Library Page Header
"We don't live in a dictatorship or a monarchy. I swore an oath in the military and in the Senate to preserve, protect and defend the Constitution of the United States, not to mindlessly cater to the whims of Cadet Bone Spurs and clap when he demands I clap,"
~ Sen. Tammy Duckworth
Purpose XMLQuery returns query results as XML. XMLTable returns results as relational data.
Create Schema
Create Demo Table conn uwclass/uwclass@pdbdev

CREATE TABLE person_data (
person_id   NUMBER(3),
person_data sys.XMLTYPE);

desc person_data
Load Demo Data INSERT INTO person_data
(person_id, person_data)
   <PDName>Daniel Morgan</PDName>

INSERT INTO person_data
(person_id, person_data)
   <PDName>Julian Dyke</PDName>

INSERT INTO person_data
(person_id, person_data)
   <PDName>Caleb Small</PDName>


set long 100000
col person_data format a60

SELECT * FROM person_data;
Simple XMLTABLE Query (with equals) SELECT <column_list>, XMLQuery (
'for $i IN <record_end_tag>
 where $i<item_end_tag> = <value>
 order by $i<item_end_tag>
 return $i<item_end_tag>
PASSING BY VALUE <xml_record_column>
RETURNING CONTENTS) <returning_column_alias>
FROM <table_name>;

Note: What is within the parentheses is case sensitive and you can not use Upper Case or InitCap for commands.
col column_value format a50

SELECT t.column_value
FROM person_data a,
    'for $root in $date
     where $root/PDRecord/PDName = "Daniel Morgan"
     return $root/PDRecord/PDDOB/text()'
  passing a.person_data AS "date") t;

Related Topics
XML Functions
XML Tables
What's New In 12cR1
What's New In 12cR2

Morgan's Library Page Footer
This site is maintained by Dan Morgan. Last Updated: This site is protected by copyright and trademark laws under U.S. and International law. © 1998-2017 Daniel A. Morgan All Rights Reserved