CREATE SCHEMA testxmlschema;
CREATE TABLE testxmlschema.test1 (a int, b text);
INSERT INTO testxmlschema.test1 VALUES (1, 'one'), (2, 'two'), (-1, null);
CREATE DOMAIN testxmldomain AS varchar;
CREATE TABLE testxmlschema.test2 (z int, y varchar(500), x char(6), w numeric(9,2), v smallint, u bigint, t real, s time, r timestamp, q date, p xml, o testxmldomain, n bool, m bytea, aaa text);
ALTER TABLE testxmlschema.test2 DROP COLUMN aaa;
INSERT INTO testxmlschema.test2 VALUES (55, 'abc', 'def', 98.6, 2, 999, 0, '21:07', '2009-06-08 21:07:30', '2009-06-08', NULL, 'ABC', true, 'XYZ');
SELECT table_to_xml('testxmlschema.test1', false, false, '');
table_to_xml
---------------------------------------------------------------
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
(1 row)
SELECT table_to_xml('testxmlschema.test1', true, false, 'foo');
table_to_xml
---------------------------------------------------------------------------
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
+
(1 row)
SELECT table_to_xml('testxmlschema.test1', false, true, '');
table_to_xml
---------------------------------------------------------------
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
(1 row)
SELECT table_to_xml('testxmlschema.test1', true, true, '');
table_to_xml
---------------------------------------------------------------
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
(1 row)
SELECT table_to_xml('testxmlschema.test2', false, false, '');
table_to_xml
---------------------------------------------------------------
+
+
+
55 +
abc +
def +
98.60 +
2 +
999 +
0 +
21:07:00 +
2009-06-08T21:07:30 +
2009-06-08
+
ABC +
true +
WFla +
+
+
+
(1 row)
SELECT table_to_xmlschema('testxmlschema.test1', false, false, '');
table_to_xmlschema
-----------------------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT table_to_xmlschema('testxmlschema.test1', true, false, '');
table_to_xmlschema
-----------------------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT table_to_xmlschema('testxmlschema.test1', false, true, 'foo');
table_to_xmlschema
----------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT table_to_xmlschema('testxmlschema.test1', true, true, '');
table_to_xmlschema
------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT table_to_xmlschema('testxmlschema.test2', false, false, '');
table_to_xmlschema
-----------------------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT table_to_xml_and_xmlschema('testxmlschema.test1', false, false, '');
table_to_xml_and_xmlschema
-----------------------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
(1 row)
SELECT table_to_xml_and_xmlschema('testxmlschema.test1', true, false, '');
table_to_xml_and_xmlschema
-----------------------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
+
(1 row)
SELECT table_to_xml_and_xmlschema('testxmlschema.test1', false, true, '');
table_to_xml_and_xmlschema
----------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
(1 row)
SELECT table_to_xml_and_xmlschema('testxmlschema.test1', true, true, 'foo');
table_to_xml_and_xmlschema
------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
(1 row)
SELECT query_to_xml('SELECT * FROM testxmlschema.test1', false, false, '');
query_to_xml
---------------------------------------------------------------
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
(1 row)
SELECT query_to_xmlschema('SELECT * FROM testxmlschema.test1', false, false, '');
query_to_xmlschema
----------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT query_to_xml_and_xmlschema('SELECT * FROM testxmlschema.test1', true, true, '');
query_to_xml_and_xmlschema
------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
(1 row)
DECLARE xc CURSOR WITH HOLD FOR SELECT * FROM testxmlschema.test1 ORDER BY 1, 2;
SELECT cursor_to_xml('xc'::refcursor, 5, false, true, '');
cursor_to_xml
-------------------------------------------------------------
+
-1 +
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
(1 row)
SELECT cursor_to_xmlschema('xc'::refcursor, false, true, '');
cursor_to_xmlschema
----------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
MOVE BACKWARD ALL IN xc;
SELECT cursor_to_xml('xc'::refcursor, 5, true, false, '');
cursor_to_xml
---------------------------------------------------------------
+
+
+
-1 +
+
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
(1 row)
SELECT cursor_to_xmlschema('xc'::refcursor, true, false, '');
cursor_to_xmlschema
------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT schema_to_xml('testxmlschema', false, true, '');
schema_to_xml
-----------------------------------------------------------------------
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
+
55 +
abc +
def +
98.60 +
2 +
999 +
0 +
21:07:00 +
2009-06-08T21:07:30 +
2009-06-08
+
ABC +
true +
WFla +
+
+
+
+
(1 row)
SELECT schema_to_xml('testxmlschema', true, false, '');
schema_to_xml
-----------------------------------------------------------------------
+
+
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
+
+
+
+
+
55 +
abc +
def +
98.60 +
2 +
999 +
0 +
21:07:00 +
2009-06-08T21:07:30 +
2009-06-08
+
+
ABC +
true +
WFla +
+
+
+
+
+
(1 row)
SELECT schema_to_xmlschema('testxmlschema', false, true, '');
schema_to_xmlschema
-------------------------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT schema_to_xmlschema('testxmlschema', true, false, '');
schema_to_xmlschema
---------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
(1 row)
SELECT schema_to_xml_and_xmlschema('testxmlschema', true, true, 'foo');
schema_to_xml_and_xmlschema
-------------------------------------------------------------------------------------------------------------------
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
1 +
one +
+
+
+
2 +
two +
+
+
+
-1 +
+
+
+
+
+
55 +
abc +
def +
98.60 +
2 +
999 +
0 +
21:07:00 +
2009-06-08T21:07:30 +
2009-06-08
+
+
ABC +
true +
WFla +
+
+
+
+
(1 row)
-- test that domains are transformed like their base types
CREATE DOMAIN testboolxmldomain AS bool;
CREATE DOMAIN testdatexmldomain AS date;
CREATE TABLE testxmlschema.test3
AS SELECT true c1,
true::testboolxmldomain c2,
'2013-02-21'::date c3,
'2013-02-21'::testdatexmldomain c4;
SELECT xmlforest(c1, c2, c3, c4) FROM testxmlschema.test3;
xmlforest
------------------------------------------------------------------
truetrue2013-02-212013-02-21
(1 row)
SELECT table_to_xml('testxmlschema.test3', true, true, '');
table_to_xml
---------------------------------------------------------------
+
true +
true +
2013-02-21 +
2013-02-21 +
+
+
(1 row)