mirror of
https://github.com/postgres/postgres.git
synced 2025-07-18 17:42:25 +03:00
Accept TEXT and CDATA nodes in XMLTABLE's column_expression.
Column expressions that match TEXT or CDATA nodes must return the contents of the nodes themselves, not the content of non-existing children (i.e. the empty string). Author: Markus Winand Reported-by: Markus Winand Reviewed-by: Álvaro Herrera Discussion: https://postgr.es/m/0684A598-002C-42A2-AE12-F024A324EAE4@winand.at
This commit is contained in:
@ -1024,7 +1024,7 @@ SELECT xmltable.*
|
||||
PASSING data
|
||||
COLUMNS id int PATH '@id',
|
||||
_id FOR ORDINALITY,
|
||||
country_name text PATH 'COUNTRY_NAME' NOT NULL,
|
||||
country_name text PATH 'COUNTRY_NAME/text()' NOT NULL,
|
||||
country_id text PATH 'COUNTRY_ID',
|
||||
region_id int PATH 'REGION_ID',
|
||||
size float PATH 'SIZE',
|
||||
@ -1046,7 +1046,7 @@ CREATE VIEW xmltableview1 AS SELECT xmltable.*
|
||||
PASSING data
|
||||
COLUMNS id int PATH '@id',
|
||||
_id FOR ORDINALITY,
|
||||
country_name text PATH 'COUNTRY_NAME' NOT NULL,
|
||||
country_name text PATH 'COUNTRY_NAME/text()' NOT NULL,
|
||||
country_id text PATH 'COUNTRY_ID',
|
||||
region_id int PATH 'REGION_ID',
|
||||
size float PATH 'SIZE',
|
||||
@ -1075,7 +1075,7 @@ CREATE OR REPLACE VIEW public.xmltableview1 AS
|
||||
"xmltable".premier_name
|
||||
FROM ( SELECT xmldata.data
|
||||
FROM xmldata) x,
|
||||
LATERAL XMLTABLE(('/ROWS/ROW'::text) PASSING (x.data) COLUMNS id integer PATH ('@id'::text), _id FOR ORDINALITY, country_name text PATH ('COUNTRY_NAME'::text) NOT NULL, country_id text PATH ('COUNTRY_ID'::text), region_id integer PATH ('REGION_ID'::text), size double precision PATH ('SIZE'::text), unit text PATH ('SIZE/@unit'::text), premier_name text DEFAULT ('not specified'::text) PATH ('PREMIER_NAME'::text))
|
||||
LATERAL XMLTABLE(('/ROWS/ROW'::text) PASSING (x.data) COLUMNS id integer PATH ('@id'::text), _id FOR ORDINALITY, country_name text PATH ('COUNTRY_NAME/text()'::text) NOT NULL, country_id text PATH ('COUNTRY_ID'::text), region_id integer PATH ('REGION_ID'::text), size double precision PATH ('SIZE'::text), unit text PATH ('SIZE/@unit'::text), premier_name text DEFAULT ('not specified'::text) PATH ('PREMIER_NAME'::text))
|
||||
EXPLAIN (COSTS OFF) SELECT * FROM xmltableview1;
|
||||
QUERY PLAN
|
||||
-----------------------------------------
|
||||
@ -1085,15 +1085,15 @@ EXPLAIN (COSTS OFF) SELECT * FROM xmltableview1;
|
||||
(3 rows)
|
||||
|
||||
EXPLAIN (COSTS OFF, VERBOSE) SELECT * FROM xmltableview1;
|
||||
QUERY PLAN
|
||||
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||
QUERY PLAN
|
||||
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||
Nested Loop
|
||||
Output: "xmltable".id, "xmltable"._id, "xmltable".country_name, "xmltable".country_id, "xmltable".region_id, "xmltable".size, "xmltable".unit, "xmltable".premier_name
|
||||
-> Seq Scan on public.xmldata
|
||||
Output: xmldata.data
|
||||
-> Table Function Scan on "xmltable"
|
||||
Output: "xmltable".id, "xmltable"._id, "xmltable".country_name, "xmltable".country_id, "xmltable".region_id, "xmltable".size, "xmltable".unit, "xmltable".premier_name
|
||||
Table Function Call: XMLTABLE(('/ROWS/ROW'::text) PASSING (xmldata.data) COLUMNS id integer PATH ('@id'::text), _id FOR ORDINALITY, country_name text PATH ('COUNTRY_NAME'::text) NOT NULL, country_id text PATH ('COUNTRY_ID'::text), region_id integer PATH ('REGION_ID'::text), size double precision PATH ('SIZE'::text), unit text PATH ('SIZE/@unit'::text), premier_name text DEFAULT ('not specified'::text) PATH ('PREMIER_NAME'::text))
|
||||
Table Function Call: XMLTABLE(('/ROWS/ROW'::text) PASSING (xmldata.data) COLUMNS id integer PATH ('@id'::text), _id FOR ORDINALITY, country_name text PATH ('COUNTRY_NAME/text()'::text) NOT NULL, country_id text PATH ('COUNTRY_ID'::text), region_id integer PATH ('REGION_ID'::text), size double precision PATH ('SIZE'::text), unit text PATH ('SIZE/@unit'::text), premier_name text DEFAULT ('not specified'::text) PATH ('PREMIER_NAME'::text))
|
||||
(7 rows)
|
||||
|
||||
-- XMLNAMESPACES tests
|
||||
|
@ -1004,7 +1004,7 @@ SELECT xmltable.*
|
||||
PASSING data
|
||||
COLUMNS id int PATH '@id',
|
||||
_id FOR ORDINALITY,
|
||||
country_name text PATH 'COUNTRY_NAME' NOT NULL,
|
||||
country_name text PATH 'COUNTRY_NAME/text()' NOT NULL,
|
||||
country_id text PATH 'COUNTRY_ID',
|
||||
region_id int PATH 'REGION_ID',
|
||||
size float PATH 'SIZE',
|
||||
@ -1026,7 +1026,7 @@ CREATE VIEW xmltableview1 AS SELECT xmltable.*
|
||||
PASSING data
|
||||
COLUMNS id int PATH '@id',
|
||||
_id FOR ORDINALITY,
|
||||
country_name text PATH 'COUNTRY_NAME' NOT NULL,
|
||||
country_name text PATH 'COUNTRY_NAME/text()' NOT NULL,
|
||||
country_id text PATH 'COUNTRY_ID',
|
||||
region_id int PATH 'REGION_ID',
|
||||
size float PATH 'SIZE',
|
||||
@ -1055,7 +1055,7 @@ CREATE OR REPLACE VIEW public.xmltableview1 AS
|
||||
"xmltable".premier_name
|
||||
FROM ( SELECT xmldata.data
|
||||
FROM xmldata) x,
|
||||
LATERAL XMLTABLE(('/ROWS/ROW'::text) PASSING (x.data) COLUMNS id integer PATH ('@id'::text), _id FOR ORDINALITY, country_name text PATH ('COUNTRY_NAME'::text) NOT NULL, country_id text PATH ('COUNTRY_ID'::text), region_id integer PATH ('REGION_ID'::text), size double precision PATH ('SIZE'::text), unit text PATH ('SIZE/@unit'::text), premier_name text DEFAULT ('not specified'::text) PATH ('PREMIER_NAME'::text))
|
||||
LATERAL XMLTABLE(('/ROWS/ROW'::text) PASSING (x.data) COLUMNS id integer PATH ('@id'::text), _id FOR ORDINALITY, country_name text PATH ('COUNTRY_NAME/text()'::text) NOT NULL, country_id text PATH ('COUNTRY_ID'::text), region_id integer PATH ('REGION_ID'::text), size double precision PATH ('SIZE'::text), unit text PATH ('SIZE/@unit'::text), premier_name text DEFAULT ('not specified'::text) PATH ('PREMIER_NAME'::text))
|
||||
EXPLAIN (COSTS OFF) SELECT * FROM xmltableview1;
|
||||
QUERY PLAN
|
||||
-----------------------------------------
|
||||
@ -1065,15 +1065,15 @@ EXPLAIN (COSTS OFF) SELECT * FROM xmltableview1;
|
||||
(3 rows)
|
||||
|
||||
EXPLAIN (COSTS OFF, VERBOSE) SELECT * FROM xmltableview1;
|
||||
QUERY PLAN
|
||||
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||
QUERY PLAN
|
||||
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
|
||||
Nested Loop
|
||||
Output: "xmltable".id, "xmltable"._id, "xmltable".country_name, "xmltable".country_id, "xmltable".region_id, "xmltable".size, "xmltable".unit, "xmltable".premier_name
|
||||
-> Seq Scan on public.xmldata
|
||||
Output: xmldata.data
|
||||
-> Table Function Scan on "xmltable"
|
||||
Output: "xmltable".id, "xmltable"._id, "xmltable".country_name, "xmltable".country_id, "xmltable".region_id, "xmltable".size, "xmltable".unit, "xmltable".premier_name
|
||||
Table Function Call: XMLTABLE(('/ROWS/ROW'::text) PASSING (xmldata.data) COLUMNS id integer PATH ('@id'::text), _id FOR ORDINALITY, country_name text PATH ('COUNTRY_NAME'::text) NOT NULL, country_id text PATH ('COUNTRY_ID'::text), region_id integer PATH ('REGION_ID'::text), size double precision PATH ('SIZE'::text), unit text PATH ('SIZE/@unit'::text), premier_name text DEFAULT ('not specified'::text) PATH ('PREMIER_NAME'::text))
|
||||
Table Function Call: XMLTABLE(('/ROWS/ROW'::text) PASSING (xmldata.data) COLUMNS id integer PATH ('@id'::text), _id FOR ORDINALITY, country_name text PATH ('COUNTRY_NAME/text()'::text) NOT NULL, country_id text PATH ('COUNTRY_ID'::text), region_id integer PATH ('REGION_ID'::text), size double precision PATH ('SIZE'::text), unit text PATH ('SIZE/@unit'::text), premier_name text DEFAULT ('not specified'::text) PATH ('PREMIER_NAME'::text))
|
||||
(7 rows)
|
||||
|
||||
-- XMLNAMESPACES tests
|
||||
|
@ -349,7 +349,7 @@ SELECT xmltable.*
|
||||
PASSING data
|
||||
COLUMNS id int PATH '@id',
|
||||
_id FOR ORDINALITY,
|
||||
country_name text PATH 'COUNTRY_NAME' NOT NULL,
|
||||
country_name text PATH 'COUNTRY_NAME/text()' NOT NULL,
|
||||
country_id text PATH 'COUNTRY_ID',
|
||||
region_id int PATH 'REGION_ID',
|
||||
size float PATH 'SIZE',
|
||||
@ -362,7 +362,7 @@ CREATE VIEW xmltableview1 AS SELECT xmltable.*
|
||||
PASSING data
|
||||
COLUMNS id int PATH '@id',
|
||||
_id FOR ORDINALITY,
|
||||
country_name text PATH 'COUNTRY_NAME' NOT NULL,
|
||||
country_name text PATH 'COUNTRY_NAME/text()' NOT NULL,
|
||||
country_id text PATH 'COUNTRY_ID',
|
||||
region_id int PATH 'REGION_ID',
|
||||
size float PATH 'SIZE',
|
||||
|
Reference in New Issue
Block a user