diff --git a/src/backend/utils/adt/xml.c b/src/backend/utils/adt/xml.c
index 2c7f778cfdb..0953ad2becb 100644
--- a/src/backend/utils/adt/xml.c
+++ b/src/backend/utils/adt/xml.c
@@ -4199,7 +4199,9 @@ xml_xmlnodetoxmltype(xmlNodePtr cur, PgXmlErrorContext *xmlerrcxt)
{
xmltype *result = NULL;
- if (cur->type != XML_ATTRIBUTE_NODE && cur->type != XML_TEXT_NODE)
+ if (cur->type != XML_ATTRIBUTE_NODE &&
+ cur->type != XML_TEXT_NODE &&
+ cur->type != XML_NAMESPACE_DECL)
{
void (*volatile nodefree) (xmlNodePtr) = NULL;
volatile xmlBufferPtr buf = NULL;
diff --git a/src/test/regress/expected/xml.out b/src/test/regress/expected/xml.out
index 449733f8ae9..3e80a7ff465 100644
--- a/src/test/regress/expected/xml.out
+++ b/src/test/regress/expected/xml.out
@@ -944,6 +944,12 @@ SELECT xpath('root', '');
{}
(1 row)
+SELECT xpath('//namespace::foo', '');
+ xpath
+--------------------
+ {http://127.0.0.1}
+(1 row)
+
-- Round-trip non-ASCII data through xpath().
DO $$
DECLARE
diff --git a/src/test/regress/expected/xml_1.out b/src/test/regress/expected/xml_1.out
index a962fce36b9..2697c68a511 100644
--- a/src/test/regress/expected/xml_1.out
+++ b/src/test/regress/expected/xml_1.out
@@ -687,6 +687,11 @@ ERROR: unsupported XML feature
LINE 1: SELECT xpath('root', '');
^
DETAIL: This functionality requires the server to be built with libxml support.
+SELECT xpath('//namespace::foo', '');
+ERROR: unsupported XML feature
+LINE 1: SELECT xpath('//namespace::foo', '');
-- Round-trip non-ASCII data through xpath().
DO $$