Mysql
 sql >> Datenbank >  >> RDS >> Mysql

'IF' in 'SELECT'-Anweisung - Ausgabewert basierend auf Spaltenwerten auswählen

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

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

Darüber hinaus könnten Sie behandeln, wenn die Bedingung null ist. Im Falle eines Nullbetrags:

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

Der Teil IFNULL(amount,0) bedeutet wenn der Betrag nicht null ist, wird der Betrag zurückgegeben, sonst wird 0 zurückgegeben .