sql >> Database >  >> RDS >> Mysql

verwijder min. waarden uit records na vergelijking van twee waarden uit tabel in sql

Zoek de rijen die u wilt verwijderen met deze zoekopdracht:

select t0.* 
from tbl_entso_cdbf t0
join tbl_entso_cdbf t1
  on  t1.Utc  = t0.Utc
  and t1.date = t0.date
  and t1.area_in  = t0.area_out
  and t1.area_out = t0.area_in
where t0.value = 0
  and (t1.value <> 0 or t1.area_in < t0.area_in);

De voorwaarden zijn:

  • value = 0
  • Er is nog een rij met dezelfde Utc en dezelfde date maar area_in en area_out zijn verwisseld.
  • De value van de andere rij is niet 0 of area_in is kleiner.

De zoekopdracht levert de volgende rijen op:

|               Utc |                date | area_in | area_out | value |
|-------------------|---------------------|---------|----------|-------|
| 2015-12-05T03:00Z | 2015-12-05 03:00:00 |      40 |      275 |     0 |
| 2015-12-06T03:00Z | 2015-12-06 03:00:00 |     175 |      100 |     0 |
| 2015-11-04T03:00Z | 2015-11-04 03:00:00 |     310 |      280 |     0 |
| 2016-09-19T00:00Z | 2016-09-19 00:00:00 |     292 |      187 |     0 |

Gebruik het nu in een subquery van de delete-instructie:

delete t1
from tbl_entso_cdbf t1
natural join (
    select t0.*
    from tbl_entso_cdbf t0
    join tbl_entso_cdbf t1
      on  t1.Utc  = t0.Utc
      and t1.date = t0.date
      and t1.area_in  = t0.area_out
      and t1.area_out = t0.area_in
    where t0.value = 0
      and (t1.value <> 0 or t1.area_in < t0.area_in)    
) t0;

NATURAL JOIN betekent dat alle kolomwaarden gelijk moeten zijn. Als u een primaire (of een unieke) sleutel had, hoeft u alleen de kolommen met de primaire (unieke) sleutel in de subquery te selecteren in plaats van * .

Nu zijn alleen de volgende rijen over in de tabel:

|               Utc |                date | area_in | area_out | value |
|-------------------|---------------------|---------|----------|-------|
| 2015-12-05T03:00Z | 2015-12-05 03:00:00 |     275 |       40 |   320 |
| 2015-12-06T03:00Z | 2015-12-06 03:00:00 |     100 |      175 |   550 |
| 2015-11-04T03:00Z | 2015-11-04 03:00:00 |     280 |      310 |     0 |
| 2016-09-19T00:00Z | 2016-09-19 00:00:00 |     187 |      292 |    45 |


  1. Enkele aanhalingstekens ontsnappen in SQL Server

  2. MySQL/SQL:update met gecorreleerde subquery vanuit de bijgewerkte tabel zelf

  3. PL/pgSQL voor alles-in-één dynamische query

  4. Hoe een subquery opnieuw te gebruiken in sql?