sql >> Database >  >> RDS >> Mysql

'IF' in 'SELECT'-statement - kies uitvoerwaarde op basis van kolomwaarden

SELECT id, 
       IF(type = 'P', amount, amount * -1) as amount
FROM report

Zie http://dev.mysql.com/ doc/refman/5.0/en/control-flow-functions.html .

Bovendien zou u kunnen afhandelen wanneer de voorwaarde null is. In het geval van een nulbedrag:

SELECT id, 
       IF(type = 'P', IFNULL(amount,0), IFNULL(amount,0) * -1) as amount
FROM report

Het deel IFNULL(amount,0) betekent wanneer bedrag niet nul is, bedrag teruggeven anders 0 retourneren .



  1. Hoe lid te worden van de eerste rij

  2. Trefwoord niet ondersteund:metadata

  3. MySql Error 150 - Buitenlandse sleutels

  4. Primaire sleutels in SQL Server