diff --git a/src/test/regress/expected/xmlmap.out b/src/test/regress/expected/xmlmap.out new file mode 100644 index 0000000000000000000000000000000000000000..c074761b60b1aecd4c464b11abe37acdbef1c5af --- /dev/null +++ b/src/test/regress/expected/xmlmap.out @@ -0,0 +1,1202 @@ +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 +--------------------------------------------------------------- + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <row> + <a>1</a> + <b>one</b> + </row> + + <row> + <a>2</a> + <b>two</b> + </row> + + <row> + <a>-1</a> + </row> + + </test1> + +(1 row) + +SELECT table_to_xml('testxmlschema.test1', true, false, 'foo'); + table_to_xml +--------------------------------------------------------------------------- + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="foo"> + + <row> + <a>1</a> + <b>one</b> + </row> + + <row> + <a>2</a> + <b>two</b> + </row> + + <row> + <a>-1</a> + <b xsi:nil="true"/> + </row> + + </test1> + +(1 row) + +SELECT table_to_xml('testxmlschema.test1', false, true, ''); + table_to_xml +--------------------------------------------------------------- + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>1</a> + <b>one</b> + </test1> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>2</a> + <b>two</b> + </test1> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>-1</a> + </test1> + + +(1 row) + +SELECT table_to_xml('testxmlschema.test1', true, true, ''); + table_to_xml +--------------------------------------------------------------- + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>1</a> + <b>one</b> + </test1> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>2</a> + <b>two</b> + </test1> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>-1</a> + <b xsi:nil="true"/> + </test1> + + +(1 row) + +SELECT table_to_xml('testxmlschema.test2', false, false, ''); + table_to_xml +--------------------------------------------------------------- + <test2 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <row> + <z>55</z> + <y>abc</y> + <x>def </x> + <w>98.60</w> + <v>2</v> + <u>999</u> + <t>0</t> + <s>21:07:00</s> + <r>2009-06-08T21:07:30</r> + <q>2009-06-08</q> + <o>ABC</o> + <n>true</n> + <m>WFla</m> + </row> + + </test2> + +(1 row) + +SELECT table_to_xmlschema('testxmlschema.test1', false, false, ''); + table_to_xmlschema +----------------------------------------------------------------------------------------------------------------- + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" minOccurs="0"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" minOccurs="0"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:complexType name="TableType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="row" type="RowType.regression.testxmlschema.test1" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test1" type="TableType.regression.testxmlschema.test1"/> + + </xsd:schema> +(1 row) + +SELECT table_to_xmlschema('testxmlschema.test1', true, false, ''); + table_to_xmlschema +----------------------------------------------------------------------------------------------------------------- + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" nillable="true"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" nillable="true"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:complexType name="TableType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="row" type="RowType.regression.testxmlschema.test1" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test1" type="TableType.regression.testxmlschema.test1"/> + + </xsd:schema> +(1 row) + +SELECT table_to_xmlschema('testxmlschema.test1', false, true, 'foo'); + table_to_xmlschema +---------------------------------------------------------------------------------------------- + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema" + targetNamespace="foo" + elementFormDefault="qualified"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" minOccurs="0"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" minOccurs="0"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test1" type="RowType.regression.testxmlschema.test1"/> + + </xsd:schema> +(1 row) + +SELECT table_to_xmlschema('testxmlschema.test1', true, true, ''); + table_to_xmlschema +------------------------------------------------------------------------------------------------ + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" nillable="true"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" nillable="true"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test1" type="RowType.regression.testxmlschema.test1"/> + + </xsd:schema> +(1 row) + +SELECT table_to_xmlschema('testxmlschema.test2', false, false, ''); + table_to_xmlschema +----------------------------------------------------------------------------------------------------------------- + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="VARCHAR"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="CHAR"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="NUMERIC"> + </xsd:simpleType> + + <xsd:simpleType name="SMALLINT"> + <xsd:restriction base="xsd:short"> + <xsd:maxInclusive value="32767"/> + <xsd:minInclusive value="-32768"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="BIGINT"> + <xsd:restriction base="xsd:long"> + <xsd:maxInclusive value="9223372036854775807"/> + <xsd:minInclusive value="-9223372036854775808"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="REAL"> + <xsd:restriction base="xsd:float"></xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="TIME"> + <xsd:restriction base="xsd:time"> + <xsd:pattern value="\p{Nd}{2}:\p{Nd}{2}:\p{Nd}{2}(.\p{Nd}+)?"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="TIMESTAMP"> + <xsd:restriction base="xsd:dateTime"> + <xsd:pattern value="\p{Nd}{4}-\p{Nd}{2}-\p{Nd}{2}T\p{Nd}{2}:\p{Nd}{2}:\p{Nd}{2}(.\p{Nd}+)?"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="DATE"> + <xsd:restriction base="xsd:date"> + <xsd:pattern value="\p{Nd}{4}-\p{Nd}{2}-\p{Nd}{2}"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType mixed="true"> + <xsd:sequence> + <xsd:any name="element" minOccurs="0" maxOccurs="unbounded" processContents="skip"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:simpleType name="Domain.regression.public.testxmldomain"> + <xsd:restriction base="VARCHAR"/> + </xsd:simpleType> + + <xsd:simpleType name="BOOLEAN"> + <xsd:restriction base="xsd:boolean"></xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.bytea"> + <xsd:restriction base="xsd:base64Binary"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test2"> + <xsd:sequence> + <xsd:element name="z" type="INTEGER" minOccurs="0"></xsd:element> + <xsd:element name="y" type="VARCHAR" minOccurs="0"></xsd:element> + <xsd:element name="x" type="CHAR" minOccurs="0"></xsd:element> + <xsd:element name="w" type="NUMERIC" minOccurs="0"></xsd:element> + <xsd:element name="v" type="SMALLINT" minOccurs="0"></xsd:element> + <xsd:element name="u" type="BIGINT" minOccurs="0"></xsd:element> + <xsd:element name="t" type="REAL" minOccurs="0"></xsd:element> + <xsd:element name="s" type="TIME" minOccurs="0"></xsd:element> + <xsd:element name="r" type="TIMESTAMP" minOccurs="0"></xsd:element> + <xsd:element name="q" type="DATE" minOccurs="0"></xsd:element> + <xsd:element name="p" type="XML" minOccurs="0"></xsd:element> + <xsd:element name="o" type="Domain.regression.public.testxmldomain" minOccurs="0"></xsd:element> + <xsd:element name="n" type="BOOLEAN" minOccurs="0"></xsd:element> + <xsd:element name="m" type="UDT.regression.pg_catalog.bytea" minOccurs="0"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:complexType name="TableType.regression.testxmlschema.test2"> + <xsd:sequence> + <xsd:element name="row" type="RowType.regression.testxmlschema.test2" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test2" type="TableType.regression.testxmlschema.test2"/> + + </xsd:schema> +(1 row) + +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', false, false, ''); + table_to_xml_and_xmlschema +----------------------------------------------------------------------------------------------------------------- + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="#"> + + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" minOccurs="0"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" minOccurs="0"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:complexType name="TableType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="row" type="RowType.regression.testxmlschema.test1" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test1" type="TableType.regression.testxmlschema.test1"/> + + </xsd:schema> + + <row> + <a>1</a> + <b>one</b> + </row> + + <row> + <a>2</a> + <b>two</b> + </row> + + <row> + <a>-1</a> + </row> + + </test1> + +(1 row) + +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', true, false, ''); + table_to_xml_and_xmlschema +----------------------------------------------------------------------------------------------------------------- + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="#"> + + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" nillable="true"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" nillable="true"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:complexType name="TableType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="row" type="RowType.regression.testxmlschema.test1" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test1" type="TableType.regression.testxmlschema.test1"/> + + </xsd:schema> + + <row> + <a>1</a> + <b>one</b> + </row> + + <row> + <a>2</a> + <b>two</b> + </row> + + <row> + <a>-1</a> + <b xsi:nil="true"/> + </row> + + </test1> + +(1 row) + +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', false, true, ''); + table_to_xml_and_xmlschema +---------------------------------------------------------------------------------------------- + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" minOccurs="0"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" minOccurs="0"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test1" type="RowType.regression.testxmlschema.test1"/> + + </xsd:schema> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>1</a> + <b>one</b> + </test1> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>2</a> + <b>two</b> + </test1> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>-1</a> + </test1> + + +(1 row) + +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', true, true, 'foo'); + table_to_xml_and_xmlschema +------------------------------------------------------------------------------------------------ + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema" + targetNamespace="foo" + elementFormDefault="qualified"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType.regression.testxmlschema.test1"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" nillable="true"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" nillable="true"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="test1" type="RowType.regression.testxmlschema.test1"/> + + </xsd:schema> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="foo"> + + <a>1</a> + <b>one</b> + </test1> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="foo"> + + <a>2</a> + <b>two</b> + </test1> + + <test1 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="foo"> + + <a>-1</a> + <b xsi:nil="true"/> + </test1> + + +(1 row) + +SELECT query_to_xml('SELECT * FROM testxmlschema.test1', false, false, ''); + query_to_xml +--------------------------------------------------------------- + <table xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <row> + <a>1</a> + <b>one</b> + </row> + + <row> + <a>2</a> + <b>two</b> + </row> + + <row> + <a>-1</a> + </row> + + </table> + +(1 row) + +SELECT query_to_xmlschema('SELECT * FROM testxmlschema.test1', false, false, ''); + query_to_xmlschema +---------------------------------------------------------------------------------------------- + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" minOccurs="0"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" minOccurs="0"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:complexType name="TableType"> + <xsd:sequence> + <xsd:element name="row" type="RowType" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="table" type="TableType"/> + + </xsd:schema> +(1 row) + +SELECT query_to_xml_and_xmlschema('SELECT * FROM testxmlschema.test1', true, true, ''); + query_to_xml_and_xmlschema +------------------------------------------------------------------------------------------------ + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" nillable="true"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" nillable="true"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="row" type="RowType"/> + + </xsd:schema> + + <row xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>1</a> + <b>one</b> + </row> + + <row xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>2</a> + <b>two</b> + </row> + + <row xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>-1</a> + <b xsi:nil="true"/> + </row> + + +(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 +------------------------------------------------------------- + <row xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>-1</a> + </row> + + <row xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>1</a> + <b>one</b> + </row> + + <row xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <a>2</a> + <b>two</b> + </row> + + +(1 row) + +MOVE FIRST IN xc; +SELECT cursor_to_xml('xc'::refcursor, 5, true, false, ''); + cursor_to_xml +--------------- + <row> + <a>1</a> + <b>one</b> + </row> + + <row> + <a>2</a> + <b>two</b> + </row> + + +(1 row) + +SELECT cursor_to_xmlschema('xc'::refcursor, true, false, ''); + cursor_to_xmlschema +------------------------------------------------------------------------------------------------ + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="RowType"> + <xsd:sequence> + <xsd:element name="a" type="INTEGER" nillable="true"></xsd:element> + <xsd:element name="b" type="UDT.regression.pg_catalog.text" nillable="true"></xsd:element> + </xsd:sequence> + </xsd:complexType> + + <xsd:complexType name="TableType"> + <xsd:sequence> + <xsd:element name="row" type="RowType" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="table" type="TableType"/> + + </xsd:schema> +(1 row) + +SELECT schema_to_xml('testxmlschema', false, true, ''); + schema_to_xml +----------------------------------------------------------------------- + <testxmlschema xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <test1> + + <a>1</a> + <b>one</b> + </test1> + + <test1> + + <a>2</a> + <b>two</b> + </test1> + + <test1> + + <a>-1</a> + </test1> + + + <test2> + + <z>55</z> + <y>abc</y> + <x>def </x> + <w>98.60</w> + <v>2</v> + <u>999</u> + <t>0</t> + <s>21:07:00</s> + <r>2009-06-08T21:07:30</r> + <q>2009-06-08</q> + <o>ABC</o> + <n>true</n> + <m>WFla</m> + </test2> + + + </testxmlschema> + +(1 row) + +SELECT schema_to_xml('testxmlschema', true, false, ''); + schema_to_xml +----------------------------------------------------------------------- + <testxmlschema xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> + + <test1> + + <row> + <a>1</a> + <b>one</b> + </row> + + <row> + <a>2</a> + <b>two</b> + </row> + + <row> + <a>-1</a> + <b xsi:nil="true"/> + </row> + + </test1> + + <test2> + + <row> + <z>55</z> + <y>abc</y> + <x>def </x> + <w>98.60</w> + <v>2</v> + <u>999</u> + <t>0</t> + <s>21:07:00</s> + <r>2009-06-08T21:07:30</r> + <q>2009-06-08</q> + <p xsi:nil="true"/> + <o>ABC</o> + <n>true</n> + <m>WFla</m> + </row> + + </test2> + + </testxmlschema> + +(1 row) + +SELECT schema_to_xmlschema('testxmlschema', false, true, ''); + schema_to_xmlschema +------------------------------------------------------------------------------------------------------------------- + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="VARCHAR"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="CHAR"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="NUMERIC"> + </xsd:simpleType> + + <xsd:simpleType name="SMALLINT"> + <xsd:restriction base="xsd:short"> + <xsd:maxInclusive value="32767"/> + <xsd:minInclusive value="-32768"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="BIGINT"> + <xsd:restriction base="xsd:long"> + <xsd:maxInclusive value="9223372036854775807"/> + <xsd:minInclusive value="-9223372036854775808"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="REAL"> + <xsd:restriction base="xsd:float"></xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="TIME"> + <xsd:restriction base="xsd:time"> + <xsd:pattern value="\p{Nd}{2}:\p{Nd}{2}:\p{Nd}{2}(.\p{Nd}+)?"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="TIMESTAMP"> + <xsd:restriction base="xsd:dateTime"> + <xsd:pattern value="\p{Nd}{4}-\p{Nd}{2}-\p{Nd}{2}T\p{Nd}{2}:\p{Nd}{2}:\p{Nd}{2}(.\p{Nd}+)?"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="DATE"> + <xsd:restriction base="xsd:date"> + <xsd:pattern value="\p{Nd}{4}-\p{Nd}{2}-\p{Nd}{2}"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType mixed="true"> + <xsd:sequence> + <xsd:any name="element" minOccurs="0" maxOccurs="unbounded" processContents="skip"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:simpleType name="Domain.regression.public.testxmldomain"> + <xsd:restriction base="VARCHAR"/> + </xsd:simpleType> + + <xsd:simpleType name="BOOLEAN"> + <xsd:restriction base="xsd:boolean"></xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.bytea"> + <xsd:restriction base="xsd:base64Binary"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="SchemaType.regression.testxmlschema"> + <xsd:sequence> + <xsd:element name="test1" type="RowType.regression.testxmlschema.test1" minOccurs="0" maxOccurs="unbounded"/> + <xsd:element name="test2" type="RowType.regression.testxmlschema.test2" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="testxmlschema" type="SchemaType.regression.testxmlschema"/> + + </xsd:schema> +(1 row) + +SELECT schema_to_xmlschema('testxmlschema', true, false, ''); + schema_to_xmlschema +--------------------------------------------------------------------------------------------------- + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="VARCHAR"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="CHAR"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="NUMERIC"> + </xsd:simpleType> + + <xsd:simpleType name="SMALLINT"> + <xsd:restriction base="xsd:short"> + <xsd:maxInclusive value="32767"/> + <xsd:minInclusive value="-32768"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="BIGINT"> + <xsd:restriction base="xsd:long"> + <xsd:maxInclusive value="9223372036854775807"/> + <xsd:minInclusive value="-9223372036854775808"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="REAL"> + <xsd:restriction base="xsd:float"></xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="TIME"> + <xsd:restriction base="xsd:time"> + <xsd:pattern value="\p{Nd}{2}:\p{Nd}{2}:\p{Nd}{2}(.\p{Nd}+)?"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="TIMESTAMP"> + <xsd:restriction base="xsd:dateTime"> + <xsd:pattern value="\p{Nd}{4}-\p{Nd}{2}-\p{Nd}{2}T\p{Nd}{2}:\p{Nd}{2}:\p{Nd}{2}(.\p{Nd}+)?"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="DATE"> + <xsd:restriction base="xsd:date"> + <xsd:pattern value="\p{Nd}{4}-\p{Nd}{2}-\p{Nd}{2}"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType mixed="true"> + <xsd:sequence> + <xsd:any name="element" minOccurs="0" maxOccurs="unbounded" processContents="skip"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:simpleType name="Domain.regression.public.testxmldomain"> + <xsd:restriction base="VARCHAR"/> + </xsd:simpleType> + + <xsd:simpleType name="BOOLEAN"> + <xsd:restriction base="xsd:boolean"></xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.bytea"> + <xsd:restriction base="xsd:base64Binary"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="SchemaType.regression.testxmlschema"> + <xsd:all> + <xsd:element name="test1" type="TableType.regression.testxmlschema.test1"/> + <xsd:element name="test2" type="TableType.regression.testxmlschema.test2"/> + </xsd:all> + </xsd:complexType> + + <xsd:element name="testxmlschema" type="SchemaType.regression.testxmlschema"/> + + </xsd:schema> +(1 row) + +SELECT schema_to_xml_and_xmlschema('testxmlschema', true, true, 'foo'); + schema_to_xml_and_xmlschema +------------------------------------------------------------------------------------------------------------------- + <testxmlschema xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="foo" xsi:schemaLocation="foo #"> + + <xsd:schema + xmlns:xsd="http://www.w3.org/2001/XMLSchema" + targetNamespace="foo" + elementFormDefault="qualified"> + + <xsd:simpleType name="INTEGER"> + <xsd:restriction base="xsd:int"> + <xsd:maxInclusive value="2147483647"/> + <xsd:minInclusive value="-2147483648"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.text"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="VARCHAR"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="CHAR"> + <xsd:restriction base="xsd:string"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="NUMERIC"> + </xsd:simpleType> + + <xsd:simpleType name="SMALLINT"> + <xsd:restriction base="xsd:short"> + <xsd:maxInclusive value="32767"/> + <xsd:minInclusive value="-32768"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="BIGINT"> + <xsd:restriction base="xsd:long"> + <xsd:maxInclusive value="9223372036854775807"/> + <xsd:minInclusive value="-9223372036854775808"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="REAL"> + <xsd:restriction base="xsd:float"></xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="TIME"> + <xsd:restriction base="xsd:time"> + <xsd:pattern value="\p{Nd}{2}:\p{Nd}{2}:\p{Nd}{2}(.\p{Nd}+)?"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="TIMESTAMP"> + <xsd:restriction base="xsd:dateTime"> + <xsd:pattern value="\p{Nd}{4}-\p{Nd}{2}-\p{Nd}{2}T\p{Nd}{2}:\p{Nd}{2}:\p{Nd}{2}(.\p{Nd}+)?"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="DATE"> + <xsd:restriction base="xsd:date"> + <xsd:pattern value="\p{Nd}{4}-\p{Nd}{2}-\p{Nd}{2}"/> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType mixed="true"> + <xsd:sequence> + <xsd:any name="element" minOccurs="0" maxOccurs="unbounded" processContents="skip"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:simpleType name="Domain.regression.public.testxmldomain"> + <xsd:restriction base="VARCHAR"/> + </xsd:simpleType> + + <xsd:simpleType name="BOOLEAN"> + <xsd:restriction base="xsd:boolean"></xsd:restriction> + </xsd:simpleType> + + <xsd:simpleType name="UDT.regression.pg_catalog.bytea"> + <xsd:restriction base="xsd:base64Binary"> + </xsd:restriction> + </xsd:simpleType> + + <xsd:complexType name="SchemaType.regression.testxmlschema"> + <xsd:sequence> + <xsd:element name="test1" type="RowType.regression.testxmlschema.test1" minOccurs="0" maxOccurs="unbounded"/> + <xsd:element name="test2" type="RowType.regression.testxmlschema.test2" minOccurs="0" maxOccurs="unbounded"/> + </xsd:sequence> + </xsd:complexType> + + <xsd:element name="testxmlschema" type="SchemaType.regression.testxmlschema"/> + + </xsd:schema> + + <test1> + + <a>1</a> + <b>one</b> + </test1> + + <test1> + + <a>2</a> + <b>two</b> + </test1> + + <test1> + + <a>-1</a> + <b xsi:nil="true"/> + </test1> + + + <test2> + + <z>55</z> + <y>abc</y> + <x>def </x> + <w>98.60</w> + <v>2</v> + <u>999</u> + <t>0</t> + <s>21:07:00</s> + <r>2009-06-08T21:07:30</r> + <q>2009-06-08</q> + <p xsi:nil="true"/> + <o>ABC</o> + <n>true</n> + <m>WFla</m> + </test2> + + + </testxmlschema> + +(1 row) + diff --git a/src/test/regress/expected/xmlmap_1.out b/src/test/regress/expected/xmlmap_1.out new file mode 100644 index 0000000000000000000000000000000000000000..932122f6be0fc1bce7143703fe5998f684dfb60a --- /dev/null +++ b/src/test/regress/expected/xmlmap_1.out @@ -0,0 +1,109 @@ +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, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xml('testxmlschema.test1', true, false, 'foo'); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xml('testxmlschema.test1', false, true, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xml('testxmlschema.test1', true, true, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xml('testxmlschema.test2', false, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xmlschema('testxmlschema.test1', false, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xmlschema('testxmlschema.test1', true, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xmlschema('testxmlschema.test1', false, true, 'foo'); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xmlschema('testxmlschema.test1', true, true, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xmlschema('testxmlschema.test2', false, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', false, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', true, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', false, true, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', true, true, 'foo'); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT query_to_xml('SELECT * FROM testxmlschema.test1', false, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT query_to_xmlschema('SELECT * FROM testxmlschema.test1', false, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT query_to_xml_and_xmlschema('SELECT * FROM testxmlschema.test1', true, true, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +DECLARE xc CURSOR WITH HOLD FOR SELECT * FROM testxmlschema.test1 ORDER BY 1, 2; +SELECT cursor_to_xml('xc'::refcursor, 5, false, true, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +MOVE FIRST IN xc; +SELECT cursor_to_xml('xc'::refcursor, 5, true, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT cursor_to_xmlschema('xc'::refcursor, true, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT schema_to_xml('testxmlschema', false, true, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT schema_to_xml('testxmlschema', true, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT schema_to_xmlschema('testxmlschema', false, true, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT schema_to_xmlschema('testxmlschema', true, false, ''); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. +SELECT schema_to_xml_and_xmlschema('testxmlschema', true, true, 'foo'); +ERROR: unsupported XML feature +DETAIL: This functionality requires the server to be built with libxml support. +HINT: You need to rebuild PostgreSQL using --with-libxml. diff --git a/src/test/regress/parallel_schedule b/src/test/regress/parallel_schedule index 7b4425b940ae90925fef65e19ccbdb1546493042..82a73e319cce7108de48071c62f7a103f28403a0 100644 --- a/src/test/regress/parallel_schedule +++ b/src/test/regress/parallel_schedule @@ -1,5 +1,5 @@ # ---------- -# $PostgreSQL: pgsql/src/test/regress/parallel_schedule,v 1.55 2009/01/27 12:40:15 petere Exp $ +# $PostgreSQL: pgsql/src/test/regress/parallel_schedule,v 1.56 2009/07/02 07:03:18 petere Exp $ # # By convention, we put no more than twenty tests in any one parallel group; # this limits the number of connections needed to run the tests. @@ -77,7 +77,7 @@ test: misc # ---------- # Another group of parallel tests # ---------- -test: select_views portals_p2 rules foreign_key cluster dependency guc bitmapops combocid tsearch tsdicts foreign_data window +test: select_views portals_p2 rules foreign_key cluster dependency guc bitmapops combocid tsearch tsdicts foreign_data window xmlmap # ---------- # Another group of parallel tests diff --git a/src/test/regress/serial_schedule b/src/test/regress/serial_schedule index ba93ea8520a0627bbd078a57e46d0473cc20f6e0..46731986e2059a4cd808fcb7b274cff8ed908daa 100644 --- a/src/test/regress/serial_schedule +++ b/src/test/regress/serial_schedule @@ -1,4 +1,4 @@ -# $PostgreSQL: pgsql/src/test/regress/serial_schedule,v 1.52 2009/01/27 12:40:15 petere Exp $ +# $PostgreSQL: pgsql/src/test/regress/serial_schedule,v 1.53 2009/07/02 07:03:18 petere Exp $ # This should probably be in an order similar to parallel_schedule. test: boolean test: char @@ -100,6 +100,7 @@ test: tsearch test: tsdicts test: foreign_data test: window +test: xmlmap test: plancache test: limit test: plpgsql diff --git a/src/test/regress/sql/xmlmap.sql b/src/test/regress/sql/xmlmap.sql new file mode 100644 index 0000000000000000000000000000000000000000..df1f98046d31e584aa3c617d097fb0daa672f36e --- /dev/null +++ b/src/test/regress/sql/xmlmap.sql @@ -0,0 +1,41 @@ +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, ''); +SELECT table_to_xml('testxmlschema.test1', true, false, 'foo'); +SELECT table_to_xml('testxmlschema.test1', false, true, ''); +SELECT table_to_xml('testxmlschema.test1', true, true, ''); +SELECT table_to_xml('testxmlschema.test2', false, false, ''); + +SELECT table_to_xmlschema('testxmlschema.test1', false, false, ''); +SELECT table_to_xmlschema('testxmlschema.test1', true, false, ''); +SELECT table_to_xmlschema('testxmlschema.test1', false, true, 'foo'); +SELECT table_to_xmlschema('testxmlschema.test1', true, true, ''); +SELECT table_to_xmlschema('testxmlschema.test2', false, false, ''); + +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', false, false, ''); +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', true, false, ''); +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', false, true, ''); +SELECT table_to_xml_and_xmlschema('testxmlschema.test1', true, true, 'foo'); + +SELECT query_to_xml('SELECT * FROM testxmlschema.test1', false, false, ''); +SELECT query_to_xmlschema('SELECT * FROM testxmlschema.test1', false, false, ''); +SELECT query_to_xml_and_xmlschema('SELECT * FROM testxmlschema.test1', true, true, ''); + +DECLARE xc CURSOR WITH HOLD FOR SELECT * FROM testxmlschema.test1 ORDER BY 1, 2; +SELECT cursor_to_xml('xc'::refcursor, 5, false, true, ''); +MOVE FIRST IN xc; +SELECT cursor_to_xml('xc'::refcursor, 5, true, false, ''); +SELECT cursor_to_xmlschema('xc'::refcursor, true, false, ''); + +SELECT schema_to_xml('testxmlschema', false, true, ''); +SELECT schema_to_xml('testxmlschema', true, false, ''); +SELECT schema_to_xmlschema('testxmlschema', false, true, ''); +SELECT schema_to_xmlschema('testxmlschema', true, false, ''); +SELECT schema_to_xml_and_xmlschema('testxmlschema', true, true, 'foo');