sql >> Database teknologi >  >> RDS >> Oracle

SQL:indsæt rækker med opsummerede værdier

SELECT
  LEAST(No1, No2) || ':' || GREATEST(No1, No2)     AS set_label,
  No1,
  No2,
  SUM(Amount)                               AS Amount,
  Stamp
FROM
  tbl
GROUP BY
  GROUPING SETS (
    (LEAST(No1, No2), GREATEST(No1, No2), No1, No2, Stamp),
    (LEAST(No1, No2), GREATEST(No1, No2))
  )

http://sqlfiddle.com/#!4/9afd5/18

Det ville være bedre, hvis hver række har en unik identifikator...

http://sqlfiddle.com/#!4/e9e95/1



  1. Sådan indsætter du flere rækker i MySQL

  2. ssh først med mysqldb i python

  3. MySQL:Returnerer flere kolonner fra en in-line underforespørgsel

  4. Postgres fungerer meget langsommere, når der bruges inputvariabler