Oracle
 sql >> Datenbank >  >> RDS >> Oracle

Die Verwendung von GROUP BY mit XMLCast und XMLQuery ergibt ORA-22950

Um über einen Wert zu aggregieren, muss der Wert sortierbar/hashbar sein, was bedeutet, dass zwei beliebige Werte vergleichbar sein müssen (um sortiert/gehasht zu werden). XMLType ist nicht sortierbar/hashbar. Ein Objekt/eine Klasse in Oracle ist hashbar/sortierbar, wenn es eine der speziellen Funktionen map hat oder order definiert. Siehe die entsprechende Oracle-Dokumentation .

Sie aggregieren über xcol , der ein XMLType ist Wert. Eine Lösung Ihres Problems wäre also, über etwas anderes zu aggregieren.

Basierend auf den chaotischen Informationen, die Sie uns geben, fallen mir zwei Lösungen ein ...

Lösung 1

WITH xdata AS
     (SELECT 1 AS a_id,
             xmltype ('<a>
                <b>
                    <b_id>1</b_id>
                    <val>2</val>
                </b>
                <b>
                    <b_id>1</b_id>
                    <val>3</val>
                </b>
             </a>') AS xcol
        FROM DUAL
      UNION ALL
      SELECT 2 AS a_id,
             xmltype ('<a>
                <b>
                    <b_id>3</b_id>
                    <val>5</val>
                </b>
                <b>
                    <b_id>4</b_id>
                    <val>4</val>
                </b>
             </a>') AS xcol
        FROM DUAL)
SELECT a_id,
     sum(XMLCAST (
         XMLQUERY ('sum($doc/a/b/val)'
                   PASSING xcol AS "doc" RETURNING CONTENT) AS INTEGER))
         b_val
FROM xdata
group by a_id;

Lösung 2

WITH xdata AS
     (SELECT 1 AS a_id,
             xmltype ('<a>
                <b>
                    <b_id>1</b_id>
                    <val>2</val>
                </b>
                <b>
                    <b_id>1</b_id>
                    <val>3</val>
                </b>
             </a>') AS xcol
        FROM DUAL
      UNION ALL
      SELECT 2 AS a_id,
             xmltype ('<a>
                <b>
                    <b_id>3</b_id>
                    <val>5</val>
                </b>
                <b>
                    <b_id>4</b_id>
                    <val>4</val>
                </b>
             </a>') AS xcol
        FROM DUAL)
select X.a_id, sum(Y.b_val) as b_val
from xdata X
    cross join xmltable(
        '/a/b'
        passing X.xcol
        columns
            b_val integer path 'val'
    ) Y
group by X.a_id;