设为首页收藏本站

融智技术学院

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 415|回复: 0

【数据库每日一问】在MySQL “SELECT”语句中的“IF”?

[复制链接]
MrLi 发表于 2014-3-8 14:00:01 | 显示全部楼层 |阅读模式

问:
  1. SELECT id, amount from report
复制代码

我需要统计总量,如果report.type ='P'则用amount表示,如果report.type ='N'则用-amount表示。我该如何将它添加到上面的查询?

答:
  1. SELECT
  2.         id
  3.         , IF(type = 'P', amount, amount * -1) as amount
  4. FROM    report
复制代码

可以通过这个 http://dev.mysql.com/doc/refman/ ... flow-functions.html查看
另外如果条件为空时也是允许处理的。所以在amount可以为null。
  1. SELECT
  2.         id
  3.         , IF(type = 'P', IFNULL(amount,0), IFNULL(amount,0) * -1) as amount
  4. FROM    report

  5. The part IFNULL(amount,0) means when amount is not null return amount else return 0.
复制代码

IFNULL(amount,0)部分表示金额不为空返回amount,否则返回0。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

新突破电商

小黑屋|手机版|Archiver|融智技术学院 ( 京ICP备09018999号  

GMT+8, 2018-11-21 22:43

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表