sql >> Databáze >  >> RDS >> Oracle

sql - oracle - výběr prvního a posledního záznamu pro konkrétní skupinu/sku

Můžete použít FIRST/LAST agregační funkce pro zjednodušení tohoto typu dotazu.

SQL Fiddle

Dotaz :

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;

Výsledky :

|    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. Rolling Daily Distint Counts

  2. převést regulární výraz PCRE na regulární výraz dotazu mysql

  3. Získejte součet sloupců a použijte k výpočtu procenta z celkového počtu (mySQL)

  4. Jak mohu exportovat schéma databáze v PostgreSQL?