将 XML 类型序列化为文本时,PostgreSQL 不包含 XML 声明,不是吗?

发布于 2024-10-03 07:36:30 字数 457 浏览 4 评论 0原文

SELECT xmlserialize (DOCUMENT (
  SELECT xmlroot(
    xmlelement(name root, 
      xmlelement(name value, 'test')
    ), version '1.0')
  ) AS text);

返回:

<根><值>测试

我想要(并且期望):

test

我当然可以:

SELECT '<?xml version="1.0"?> ' || xmlserialize (CONTENT (...

但是包含 xmlroot 有什么意义呢?

SELECT xmlserialize (DOCUMENT (
  SELECT xmlroot(
    xmlelement(name root, 
      xmlelement(name value, 'test')
    ), version '1.0')
  ) AS text);

returns:

<root><value>test</value></root>

I want (and expected):

<?xml version='1.0'?><root><value>test</value></root>

Of course I could go:

SELECT '<?xml version="1.0"?> ' || xmlserialize (CONTENT (...

but then what is the point of including xmlroot?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

腻橙味 2024-10-10 07:36:30

(我在 Windows XP 上尝试了 v8.3.7、v8.4.4 和 v9.0.0)

如果 xmlrootstandalone 选项与值一起使用,则它包括 xml 声明

SELECT xmlserialize (DOCUMENT (
  SELECT xmlroot(
    xmlelement(name root, 
      xmlelement(name value, 'test')
    ), version '1.0', standalone yes)
  ) AS text);

(I experimented with v8.3.7, v8.4.4 & v9.0.0 on Windows XP)

It includes the xml declaration if the standalone option of xmlroot is used with a value of yes or no:

SELECT xmlserialize (DOCUMENT (
  SELECT xmlroot(
    xmlelement(name root, 
      xmlelement(name value, 'test')
    ), version '1.0', standalone yes)
  ) AS text);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文