Per aggregare tramite un valore, il valore deve essere ordinabile/hash per, il che significa che due valori qualsiasi devono essere confrontabili (per essere ordinati/hash). XMLType
non è ordinabile/hashable. Un oggetto/classe in Oracle è hashable/ordinabile quando ha una delle funzioni speciali map
o order
definito. Consulta la rispettiva documentazione Oracle
.
Stai aggregando tramite xcol
, che è un XMLType
valore. Quindi, una soluzione al tuo problema sarebbe l'aggregazione tramite qualcos'altro.
Sulla base delle informazioni caotiche che ci stai fornendo, mi vengono in mente due soluzioni ...
Soluzione 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;
Soluzione 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;