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

Sammenlign rækker i orakeltabellen, og opdater de der matcher

Ikke testet, men noget som dette bruger kun SQL:

MERGE INTO your_table dst
USING (
  SELECT ROW_NUMBER() OVER (
             PARTITION BY tDate, Product, Price, Quantity, BuySell
             ORDER BY ID
           ) AS idx,
         COUNT( CASE BuySell WHEN 'Buy' THEN 1 END ) OVER (
             PARTITION BY tDate, Product, Price, Quantity
           ) AS num_buy,
         COUNT( CASE BuySell WHEN 'Sell' THEN 1 END ) OVER (
             PARTITION BY tDate, Product, Price, Quantity
           ) AS num_sell
  FROM   your_table
) src
ON ( src.ROWID = dst.ROWID AND src.idx <= LEAST( src.num_buy, src.num_sell ) )
WHEN MATCHED THEN
  UPDATE SET Status = 'Matched';


  1. Hvordan laver man små bogstaver i Oracle-databasen?

  2. nolock på en midlertidig tabel i SQL Server 2008

  3. Er mine MySQL-serverforbindelser krypteret og sikre?

  4. Hent seneste række for givet ID