sql >> Databasteknik >  >> RDS >> Oracle

Sammanfoga rader till CLOB

Som de.hh.holger redan påpekat, LISTAGG MED CLOB? STRÄNGAGGREGATION ÖVER 4000 TECKEN MED XMLAGG löser verkligen detta problem.

Jag har utvecklat lite mer i ämnet och det här borde göra susen i händelse av ett riktigt långt strängmeddelande:

SELECT
   table_row_id,
   DBMS_XMLGEN.CONVERT (
     EXTRACT(
       xmltype('<?xml version="1.0"?><document>' ||
               XMLAGG(
                 XMLTYPE('<V>' || DBMS_XMLGEN.CONVERT(data_value)|| '</V>')
                 order by myOrder).getclobval() || '</document>'),
               '/document/V/text()').getclobval(),1) AS data_value
FROM (
   SELECT 1 myOrder, 1 table_row_id,'abcdefg>' data_value FROM dual
   UNION ALL
   SELECT 2, 1 table_row_id,'hijklmn' data_value FROM dual
   UNION ALL
   SELECT 3, 1 table_row_id,'opqrst' data_value FROM dual
   UNION ALL
   SELECT 4, 1 table_row_id,'uvwxyz' data_value FROM dual)
GROUP BY
   table_row_id


  1. Konvertera 'datetime2' till 'datetimeoffset' i SQL Server (T-SQL-exempel)

  2. MySQL-frågefel med CASE och INNER JOIN

  3. Hur man löser MySQL max_user_connections-felet

  4. Raderade rader från reflekterad tabell med SQLAlchemy