从多个表Mysql查询计数总计

问题描述 投票:0回答:1

我有列表,每个部分基本上包含相同的字段。

- p_xl_cj_ticket_m_site_data      |  - p_xl_cj_ticket     |  - p_xl_cj_ticket_last_row_ingroup
- p_xl_jabo1_ticket_m_site_data   |  - p_xl_jabo1_ticket  |  - p_xl_jabo1_ticket_last_row_ingroup
- p_xl_jabo2_ticket_m_site_data   |  - p_xl_jabo2_ticket  |  - p_xl_jabo2_ticket_last_row_ingroup

如果我想计算机票1,机票2,机票3的所有总站点,我该怎么办?

预期产出(总共3个以上表格):

enter image description here

目前的代码:

SELECT COUNT( * ) AS tot_sites, 
       IFNULL( COUNT( 
            CASE WHEN p_xl_cj_m_site_data.m_date_target = DATE( NOW( ) ) 
            THEN 1 ELSE NULL END ) , 0 ) AS todays_target, 
       IFNULL( COUNT( 
            CASE WHEN (p_xl_cj_m_site_data.m_date_target = DATE( NOW( ) ) 
                       AND p_xl_cj_ticket.t_status =9 ) 
            THEN 1 ELSE NULL END ) , 0) AS todays_achieve, 
       IFNULL( COUNT( 
            CASE WHEN p_xl_cj_ticket.t_status =9
            THEN 1 ELSE NULL END ) , 0 ) AS tot_in
FROM p_xl_cj_m_site_data
LEFT JOIN p_xl_cj_ticket_last_row_ingroup  
        ON p_xl_cj_ticket_last_row_ingroup.t_m_id = p_xl_cj_m_site_data.m_id
       AND p_xl_cj_ticket_last_row_ingroup.t_req_type =  '04_int_finish_ack'
LEFT JOIN p_xl_cj_ticket 
        ON p_xl_cj_ticket.t_id = p_xl_cj_ticket_last_row_ingroup.t_id
WHERE p_xl_cj_m_site_data.m_status =1

样本数据:

p_xl_cj_ticket_m_site_data       p_xl_cj_ticket        p_xl_cj_ticket_last_row_ingroup     
------------------------------------------------------------------------------------  
* m_date_target = 2019-02-13    * t_status = 9         * t_m_id = xxxxx123
* m_status = 1                  * t_id = abc           * t_id = abc
* m_id = xxxxx123                                      * t_req_type = 04_int_finish_ack

我当前的代码只是p_xl_cj的计票。

我该怎么办,如果想按照我的期望做出输出?

谢谢...

mysql sql database database-design relational-database
1个回答
0
投票
SELECT  (
    SELECT COUNT(*)
    FROM   <table>
    ) AS count1,
    (
    SELECT COUNT(*)
    FROM   <table>
    ) AS count2
© www.soinside.com 2019 - 2024. All rights reserved.