summer108 2019-11-26 15:06 采纳率: 0%
浏览 689

为何count(表别名.*)和count(*)结果不同?

数据库:Greenplum

查询语句:

select 
    net_type,count (a.*)
FROM
    anrpt.rpt_label_info_1_prt_p_201908 a
WHERE
    user_id IN (
        SELECT
             user_id
        FROM
            anrpt.LABEL_USERS_1_105610008  
    )
  AND flag_acct = '是'
GROUP BY
    net_type

    ```

结果:

"2G";4

查询语句:

select
net_type,count (*)
FROM
anrpt.rpt_label_info_1_prt_p_201908 a
WHERE
user_id IN (
SELECT
user_id
FROM
anrpt.LABEL_USERS_1_105610008

)
AND flag_acct = '是'
GROUP BY
net_type


结果:

"2G";227

"3G";14

-----------------

结果中cust_name字段全部为null


![图片说明](https://img-ask.csdn.net/upload/201911/28/1574912470_361380.png)
  • 写回答

1条回答 默认 最新

  • jack_h_li 2019-11-28 10:54
    关注

    count (a.*) 会去判断a*每一行字段值都不能 null 才计数1,如有任何一个字段为空将不计数
    count(*) 直接返回对应的表行记录数,所以会有不同

    建议将 count(*) 或 count(a.*) 换成 sum(1)
    希望会有用

    评论

报告相同问题?