SELECT id,
IF(type = 'P', amount, amount * -1) as amount
FROM report
Вижте http://dev.mysql.com/ doc/refman/5.0/en/control-flow-functions.html .
Освен това можете да се справите, когато условието е нула. В случай на нулева сума:
SELECT id,
IF(type = 'P', IFNULL(amount,0), IFNULL(amount,0) * -1) as amount
FROM report
Частта IFNULL(amount,0)
означава когато сумата не е нула, връщане на сума, иначе връщане на 0 .