我有四个表:如何获得使用Mysql的总“活跃”用户?
表A:users_table
表B:users_account_table
表C:fangates_table
表d:downloads_table
表A(users_table)包含3个列:ID,NAME和GATE_COUNT。表C(fangates_table)包含用户门。 表D(downloads_table)包含fangates_table_id和account_id。
TABLE A
ID | NAME | GATE_COUNT
---------------------------
1 | Joy | 2
---------------------------
2 | Ash | 0
---------------------------
3 | Nik | 2
---------------------------
4 | Wox | 0
TABLE B
ID | A_ID | ACCOUNT_ID
---------------------------
1 | 1 | 123456
---------------------------
2 | 1 | 654321
---------------------------
3 | 3 | 5888
---------------------------
4 | 3 | 8787
TABLE C
ID | A_ID | TITLE
---------------------------
1 | 1 | ABCD
---------------------------
2 | 1 | DFCV
---------------------------
3 | 3 | FGTG
---------------------------
4 | 3 | FRGTG
TABLE D
ID | C_ID | ACCOUNT_ID
---------------------------
1 | 1 | 123456
---------------------------
2 | 2 | 123456
---------------------------
3 | 3 | 7859
---------------------------
4 | 1 | 7585
从上面的表中,我试图获得总“有效”用户
我曾尝试(其中的活动用户与具有其他任何下载fangates不自理定义为用户)的在查询之后,但它失败了。
SELECT COUNT(*) FROM D
WHERE (C_ID,ACCOUNT_ID)
NOT IN
(SELECT C.ID, B.ACCOUNT_ID FROM A
LEFT JOIN B ON A.ID = B.A_ID
LEFT JOIN C ON A.ID = C.A_ID
WHERE A.GATE_COUNT >0);
什么是您的标志,以确定有效和无效的用户? –
一个活跃的用户是一个用户,他的粉丝在donwloads表中有任何下载,但不是他自己 –