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

为何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)
    希望会有用

    评论

报告相同问题?

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度