磨砺技术珠矶,践行数据之道,追求卓越价值回到上一级页面: 回到顶级页面:[作者 高健@博客园 luckyjackgao@gmail.com]
PostgreSQL及PPAS支持xml数据类型,故进行如下的实验。
先看PPAS9.2中的效果:
先建立表:
-bash-3.2$ ./bin/psql -d edbpsql (9.2.1.3)"help" でヘルプを表示します.edb=# CREATE TABLE xmltab01(books xml);CREATE TABLEedb=# INSERT INTO xmltab01(books) VALUES ('Book0001 ');INSERT 0 1edb=# INSERT INTO xmltab01(books) VALUES ('Book0002 ');INSERT 0 1edb=#
再查询:
edb=# SELECT books from xmltab01;books -------------------------Book0001 Book0002 (2 行)
然后,继续插入更复杂的数据:
edb=# INSERT INTO xmltab01(books) VALUES('edb'#edb'# ');INSERT 0 1edb=#Book0003 edb'#Author0003 edb'#Puber0003 edb'#
edb=# INSERT INTO xmltab01(books) VALUES('edb'#edb'# ');INSERT 0 1edb=#Book0004 edb'#Author0004 edb'#Puber0004 edb'#
edb=# INSERT INTO xmltab01(books) VALUES('edb'#edb'# ');INSERT 0 1edb=#Book0005 edb'#Author0004 edb'#Puber0004 edb'#
接着,进行一个带条件的查询,查找出作者为Author0004的用户所写的书的title:
不符合条件的记录也被查询出来,留下一个空值。
edb=# SELECT xpath('/book[author/text()="Author0004"]/title', books) FROM xmltab01;xpath ---------------------------{}{}{}{Book0004 }{Book0005 }(5 行)edb=#
最后删除表:
edb=# drop table xmltab01;DROP TABLEedb=#
下面是使用PostgreSQL时的情形,
初次使用发生错误,需要重新编译数据库:
postgres=# CREATE TABLE xmltab01(books xml);CREATE TABLEpostgres=# INSERT INTO xmltab01(books) VALUES ('Book0001 ');ERROR: unsupported XML featureLINE 1: INSERT INTO xmltab01(books) VALUES ('Book0001 ... ^DETAIL: This functionality requires the server to be built with libxml support.HINT: You need to rebuild PostgreSQL using --with-libxml.postgres=#
在进行了 ./configure --with-libxml gmake && gmake install 之后,
可以正常工作。
[作者 高健@博客园 luckyjackgao@gmail.com]回到上一级页面: 回到顶级页面:磨砺技术珠矶,践行数据之道,追求卓越价值