SQL 如何对多个条件进行分组?

在这个表中,请问如何以flight_id进行分组,统计每个flight_id组的is_pick为'true'的个数?
图片描述

在不使用存储过程的情况下能完成么?我使用的sqlite

阅读 8.9k
2 个回答
select flight_id,
count(*),
sum( case is_pick when true then 1 else 0 end) 
from ticket 
group by flight_id

手机打字很慢,mysql不知有没这case语法

先取is_pick=true的数据,再进行分组统计保证更好的效率

select flight_id,count(1) from ticket where is_pick=true group by flight_id

再统计不区分is_pick的直接把where条件去除就可以

select flight_id,count(1) from ticket group by flight_id
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题