Your SlideShare is downloading. ×
0
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
The Road to the XML Type: Current and Future Developments
Upcoming SlideShare
Loading in...5
×

Thanks for flagging this SlideShare!

Oops! An error has occurred.

×
Saving this for later? Get the SlideShare app to save on your phone or tablet. Read anywhere, anytime – even offline.
Text the download link to your phone
Standard text messaging rates apply

The Road to the XML Type: Current and Future Developments

1,019

Published on

originally presented at PGCon 2007

originally presented at PGCon 2007

Published in: Technology, Education
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
1,019
On Slideshare
0
From Embeds
0
Number of Embeds
0
Actions
Shares
0
Downloads
9
Comments
0
Likes
0
Embeds 0
No embeds

Report content
Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
No notes for slide

Transcript

  • 1. The Road to the XML Type Current and Future Developments Nikolay Samokhvalov Peter Eisentraut PGCon 2007
  • 2. Current Developments Future Developments Conclusion Outline 1 Current Developments 2 Future Developments 3 Conclusion Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 3. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export Outline 1 Current Developments 2 Future Developments 3 Conclusion Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 4. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export New Features Target for PostgreSQL 8.3: XML Data Type XML Publishing XML Export SQL:2003 conformance XPath Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 5. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export Outline 1 Current Developments XML Data Type XML Publishing XML Export 2 Future Developments 3 Conclusion Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 6. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XML Data Type CREATE TABLE test ( ..., data xml, ... ); Features: Input checking Support functions Issues: Internal storage format (plain text) Encoding handling Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 7. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export Using the XML Type Bizarre SQL way: INSERT INTO test VALUES ( ..., XMLPARSE (DOCUMENT ’<foo>...</foo>’), ... ); SELECT XMLSERIALIZE (DOCUMENT data AS varchar) FROM test; Simple PostgreSQL way: INSERT INTO test VALUES (... , ’<foo>...</foo>’, ...); SELECT data FROM test; Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 8. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XML Type Oddities No comparison operators To retrieve, use: Cast to text, or XPath, or Other key column To index, use: Cast to text, or XPath Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 9. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export Outline 1 Current Developments XML Data Type XML Publishing XML Export 2 Future Developments 3 Conclusion Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 10. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export Producing XML Content The old way? SELECT ’<record id="’ || id || ’"><value>’ || ad_hoc_escape_func(value) || ’</value></record>’ FROM tab; The new way: SELECT XMLELEMENT(NAME record, XMLATTRIBUTES(id), XMLELEMENT(NAME value, value)) FROM tab; Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 11. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XMLELEMENT Example Result: SQL: <?xml version=’1.0’ XMLROOT ( standalone=’yes’ ?> XMLELEMENT ( <gazonk name=’val’ NAME ’gazonk’, num=’2’> XMLATTRIBUTES ( <qux>foo</qux> ’val’ AS ’name’, </gazonk> 1 + 1 AS ’num’ ), XMLELEMENT ( NAME ’qux’, ’foo’ ) ), VERSION ’1.0’, STANDALONE YES ) Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 12. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XMLFOREST Example SELECT xmlforest ( "FirstName" as "FName", "LastName" as "LName", ’string’ as "str", "Title", "Region" ) FROM "Demo"."demo"."Employees"; might result in <FName>Nancy</FName> <LName>Davolio</LName> <str>string</str> <Title>Sales Representative</Title> <Region>WA</Region> . . . <FName>Anne</FName> <LName>Dodsworth</LName> <str>string</str> <Title>Sales Representative</Title> Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 13. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XMLAGG Example SELECT xmlelement (’Emp’, xmlattributes (’Sales Representative’ xmlagg (xmlelement (’Name’, "FirstName", ’ ’, "LastName"))) FROM "Demo"."demo"."Employees" WHERE "Title" = ’Sales Representative’; might result in <Emp Title="Sales Representative"> <Name>Nancy Davolio</Name> <Name>Janet Leverling</Name> <Name>Margaret Peacock</Name> <Name>Michael Suyama</Name> <Name>Robert King</Name> <Name>Anne Dodsworth</Name> </Emp> (1 row) Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 14. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export Outline 1 Current Developments XML Data Type XML Publishing XML Export 2 Future Developments 3 Conclusion Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 15. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XML Export Map table/schema/database contents to XML document Map table/schema/database schema to XML Schema Useful for: Downstream processing (e.g., SOAP, web services) Postprocessing using XSLT Backup??? Display formats (alternative to psql’s HTML mode) Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 16. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XML Export Functions Data export: table_to_xml(tbl regclass, nulls boolean, tableforest boolean, targetns text) query_to_xml(query text, nulls boolean, tableforest boolean, targetns text) cursor_to_xml(cursor refcursor, count int, nulls boolean, tableforest boolean, targetns text) Schema export: table_to_xmlschema(tbl regclass, nulls boolean, tableforest boolean, targetns text) query_to_xmlschema(query text, nulls boolean, tableforest boolean, targetns text) cursor_to_xmlschema(cursor refcursor, nulls boolean, tableforest boolean, targetns text) Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 17. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XML Schema Mapping Example CREATE TABLE test (a int PRIMARY KEY, b varchar(200)); is mapped to <xsd:complexType name="RowType.catalog.schema.test"> <xsd:sequence> <xsd:element name="a" type="INTEGER"></xsd:element> <xsd:element name="b" type="VARCHAR_200_200" minOccurs="0"> </xsd:sequence> </xsd:complexType> <xsd:complexType name="TableType.catalog.schema.test"> <xsd:sequence> <xsd:element name="row" type="RowType.catalog.schema.test" minOccurs="0" maxOccurs="unbounded" /> </xsd:sequence> </xsd:complexType> Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 18. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XML Export Format Example <catalogname> <schemaname> <tablename> <row> <colname1>value</colname1> <colname2 xsi:nil=’true’/> ... </row> ... </tablename> ... </schemaname> ... </catalogname> Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 19. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export Outline 1 Current Developments XML Data Type XML Publishing XML Export 2 Future Developments 3 Conclusion Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 20. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export XPath tbd Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 21. Current Developments XML Data Type Future Developments XML Publishing Conclusion XML Export External Dependencies Uses libxml (LGPL) for XML publishing and XPath Enable with configure --with-libxml Not necessary for XML export Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 22. Current Developments Future Developments Conclusion Outline 1 Current Developments 2 Future Developments 3 Conclusion Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 23. Current Developments Future Developments Conclusion Further Work/Ideas XQuery support (SQL:2006) Ctree indexes Inline ORDER BY for XMLAGG (example: ... XMLAGG(XMLELEMENT(...) ORDER BY col1) ...) Improved namespaces support JDBC support DTD, XML Schema, Relax-NG validation XSLT XML Canonical Pretty printing Shredding Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 24. Current Developments Future Developments Conclusion Outline 1 Current Developments 2 Future Developments 3 Conclusion Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type
  • 25. Current Developments Future Developments Conclusion More Information http://developer.postgresql.org/index.php/ XML_Support PostgreSQL documentation Nikolay Samokhvalov, Peter Eisentraut The Road to the XML Type

×