sql >> Database >  >> RDS >> Oracle

sql - oracle - het eerste en laatste record selecteren voor een specifieke groep/sku

U kunt gebruik maken van FIRST/LAST verzamelfuncties om dit type zoekopdracht te vereenvoudigen.

SQL Fiddle

Zoekopdracht :

select
        sku,
        max(price) keep (dense_rank first order by purchase_date) first_purchase_price,
        max(price) keep (dense_rank last order by purchase_date) last_purchase_price
from
        store
group by
        sku;

Resultaten :

|    SKU | FIRST_PURCHASE_PRICE | LAST_PURCHASE_PRICE |
|--------|----------------------|---------------------|
|  BC123 |                 3.09 |                6.68 |
|  QERT1 |                 9.09 |               13.23 |
| QQQ789 |                 4.01 |                4.01 |
|  WW000 |               200.01 |              200.01 |
|  YZV11 |               230.23 |                6.68 |


  1. 2 manieren om voorloopnullen toe te voegen in PostgreSQL

  2. Optellen uit 2 verschillende tabellen

  3. Een CSV-bestand importeren in een externe Oracle-tabel

  4. ODP.NET UPDATE... TERUGKEER IN... meerdere rijen, parametertype