MySQL - 计数在同一个表中 [英] MySQL - count in same table

查看:137
本文介绍了MySQL - 计数在同一个表中的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有下表:

+----+---------------------+---------------+
| id |     created_at      | deklaracja_id |
+----+---------------------+---------------+
|  1 | 2015-01-09 12:14:00 |             1 |/*deklaracja*/
|  2 | 2015-02-09 12:14:00 |             1 |/*korekta for 1*/
|  3 | 2015-03-09 12:14:00 |             3 |/*deklaracja/
|  4 | 2015-01-09 12:14:00 |             3 |/*korekta for 3*/
|  5 | 2015-10-09 12:14:00 |             3 |/*korekta for 3*/
|  6 | 2015-10-09 12:14:00 |             6 |/*deklaracja*/
+----+---------------------+---------------+

条件:
id = deklaracja_id isdeklaracja
id> deklaracja_id iskorekta

Cond: id = deklaracja_id is "deklaracja" id <> deklaracja_id is "korekta"

我需要一个查询来显示所有deklaracja和他们的korekty的计数晚于2015-01-09。

I need a query to show all "deklaracja" and count of their "korekty" later than 2015-01-09.

Ex.
+----+---------------------+---------------+
| id |     created_at      | korekty_count |
+----+---------------------+---------------+
|  1 | 2015-01-09 12:14:00 |             1 |
|  3 | 2015-03-09 12:14:00 |             2 |
|  6 | 2015-10-09 12:14:00 |             0 |
+----+---------------------+---------------+

我尝试过类似的操作:

SELECT *, 
SUM(CASE WHEN (id <> deklaracja_id)THEN 1 ELSE 0 END ) 
AS korekty_count 
FROM Deklaracja 
WHERE created >= '2015-09-01 00:00:00'

但不工作,现在我完全停留了:/

but it's not working and now I'm totally stuck :/

推荐答案

添加 GROUP BY

SELECT *, 
SUM(CASE WHEN (id <> deklaracja_id)THEN 1 ELSE 0 END ) 
AS korekty_count 
FROM Deklaracja 
WHERE created_at >= '2015-01-09 00:00:00' GROUP BY deklaracja_id

这篇关于MySQL - 计数在同一个表中的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆