mirror of
https://github.com/postgres/postgres.git
synced 2025-06-30 21:42:05 +03:00
It only produced <row> elements but no wrapping <table> element. By contrast, cursor_to_xmlschema produced a schema that is now correct but did not previously match the XML data produced by cursor_to_xml. In passing, also fix a minor misunderstanding about moving cursors in the tests related to this. Reported-by: filip@jirsak.org Based-on-patch-by: Thomas Munro <thomas.munro@enterprisedb.com>
43 lines
2.4 KiB
SQL
43 lines
2.4 KiB
SQL
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, '');
|
|
SELECT cursor_to_xmlschema('xc'::refcursor, false, true, '');
|
|
MOVE BACKWARD ALL 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');
|