学习SQL快一个月,一直以为count函数只能填入一个参数,如count(人名),

或者在count函数里加入其他函数,如count(if()),count(case when())。

今天在牛客网上做习题时,居然发现了一个完全没看过也没听过的count函数用法,那就是在括号里加入两个参数,下面把这道题请上来吧!

例题

用户在牛客试卷作答区作答记录存储在表exam_record中,内容如下:

exam_record表(uid用户ID, exam_id试卷ID, start_time开始作答时间, submit_time交卷时间, score得分)

id uid exam_id start_time submit_time score
1 1001 9001 2021-07-02 09:01:01 2021-07-02 09:21:01 80
2 1002 9001 2021-09-05 19:01:01 2021-09-05 19:40:01 81
3 1002 9002 2021-09-02 12:01:01 (NULL) (NULL)
4 1002 9003 2021-09-01 12:01:01 (NULL) (NULL)
5 1002 9001 2021-07-02 19:01:01 2021-07-02 19:30:01 82
6 1002 9002 2021-07-05 18:01:01 2021-07-05 18:59:02 90
7 1003 9002 2021-07-06 12:01:01 (NULL) (NULL)
8 1003 9003 2021-09-07 10:01:01 2021-09-07 10:31:01 86
9 1004 9003 2021-09-06 12:01:01 (NULL) (NULL)
10 1002 9003 2021-09-01 12:01:01 2021-09-01 12:31:01 81
11 1005 9001 2021-09-01 12:01:01 2021-09-01 12:31:01 88
12 1006 9002 2021-09-02 12:11:01 2021-09-02 12:31:01 89
13 1007 9002 2020-09-02 12:11:01 2020-09-02 12:31:01 89

请计算2021年每个月里试卷作答区用户平均月活跃天数avg_active_days和月度活跃人数mau,上面数据的示例输出如下:

month avg_active_days mau
202107 1.50 2
202109 1.25 4

解释:2021年7月有2人活跃,共活跃了3天(1001活跃1天,1002活跃2天),平均活跃天数1.5;2021年9月有4人活跃,共活跃了5天,平均活跃天数1.25,结果保留2位小数。

注:此处活跃指有交卷行为。

答案如下

select date_format(submit_time, '%Y%m') as month,round((count(distinct uid, date_format(submit_time, '%y%m%d'))) / count(distinct uid), 2) as avg_active_days,count(distinct uid) as mau
from exam_record
where submit_time is not null
and year(submit_time) = 2021
group by date_format(submit_time, '%Y%m')

答案中的第二句:

(count(distinct uid, date_format(submit_time, '%y%m%d'))

彻底把我整懵了,百思不得其解,因为之前完全不知道count函数还有这套骚操作,

如果有大神看到这里,麻烦替小白我解答疑惑,感激不尽!

求教 | SQL的count()函数里居然能加两个参数相关推荐

  1. hibernate SQL查询COUNT函数

    在Oracle11g中hibernate执行SQL语句使用COUNT聚合函数时,返回类型是BigDecimal 在MySQL5.5中COUNT聚合函数返回类型则是BigInteger 用其他类型数据接 ...

  2. SQL中count和case when结合使用统计某个条件下不重复的记录数

    目录 一.统计某一种类型的不重复的个数 二.分组后再统计某一种类型的不重复的个数 ​三.分组后统计汇总的数据和某一种类型的不重复的个数 最近遇到一个问题,需要分组统计某种类型的金额总和跟该类型的记录数 ...

  3. Oracle count函数原理,oracle count函数

    用来返回查询的行数. 当指定distinct时,不能接order_by_clause: 如果指定表达式,count返回表达式不为空的值: 当指定*号时,它返回所有行,含重复行和空值.count从不返回 ...

  4. mysql数据库中count的作用_详解 MySQL中count函数的正确使用方法

    1. 描述 在MySQL中,当我们需要获取某张表中的总行数时,一般会选择使用下面的语句 select count(*) from table; 其实count函数中除了*还可以放其他参数,比如常数.主 ...

  5. pythonint函数的参数_向嵌入的Python函数传递两个参数(int和array)

    我需要从我的模块中调用Python函数并为其设置两个参数:int和array.在 现在我在调用这个函数的时候遇到了segfault,我不知道我做错了什么.有人能指出我的错误在哪里吗?在 函数在我的Py ...

  6. C程序设计基础(5):函数基础详解(函数定义、调用、原型、参数)

      上一节中,我们学习了有关数组和字符串的常用方法.数组和字符串的加持大大降低了我们命名和使用变量的复杂程度,节约了代码量,但这还不够.程序编写过程中,我们往往会遇到一段相似的代码在多个不同的位置出现 ...

  7. R语言使用choose函数计算排列组合:组合数(输入两个参数、combination)

    R语言使用choose函数计算排列组合:组合数(输入两个参数.combination) 目录 R语言使用choose函数计算组合数(输入两个参数.combination) R 语言特点 R语言使用ch ...

  8. T-SQL里数据库工程师都不知道的秘密之SQL Server自定义函数UDF

    T-SQL SQL Server UDF自定义函数概念与案例实战 函数的定义 这里的函数指的是用户自定义函数(UDF)全名为(user-defined function),以下简称为函数. 它是数据库 ...

  9. 【3 - 查询】Sql Server - 郝斌(计算列、distinct、between、in、top、null、order by、模糊查询、聚合函数[主要是count()函数] )

    课程地址:数据库 SQLServer 视频教程全集(99P)| 22 小时从入门到精通_哔哩哔哩_bilibili ​ 目录 查询(最重要,难度最大) (一)大纲 (二)Scott 表 下载与导入SQ ...

最新文章

  1. Ubuntu安装deb软件包错误(依赖关系问题)解决
  2. java打地鼠游戏-有背景音乐有图
  3. 关于C语言的一些小知识点
  4. BZOJ 2440 完全平方数(莫比乌斯-容斥原理)
  5. python代码进去docker容器内_python脚本监控docker容器
  6. Python数据挖掘和机器学习
  7. linux 如何加密文件夹,如何加密个别文件夹?
  8. 房屋租赁合同可不可以用笔修改
  9. cnpm和npm使用,遇到的问题及解决方法
  10. MySQL 中文字段排序问题(根据中文拼音排序)
  11. Halcon椭圆测量
  12. 美大联盟中国小将3年年薪翻60倍 从第7前锋到赢新合同
  13. 洛谷 P1878 舞蹈课 —— 小顶堆
  14. elasticsearch的.security-7索引崩溃恢复笔记
  15. QQ群名片尾巴生成原理
  16. html文档中的元素分为两部分,云开HTML5开发基础与应用(20秋)形考作业2【标准答案】...
  17. 程序员锻炼腰部几个简单的方法
  18. ElasticSearch基础:从倒排索引说起,快速认知ES
  19. 到底多少够用 11款USB设备供电大揭秘
  20. 甲骨文助ISV 通过SOA与Oracle软件集成

热门文章

  1. [分享]关于mac的保修时间计算政策,附送延长保修时间秘诀
  2. 孤独匠人说:给我500万三年超马云
  3. Dejavu Sans Mono字体使用指南
  4. 魅族18双击亮屏图文设置方法(2021)
  5. “遯世无闷”与“人不知不愠”
  6. Excel动画图解:Excel标题跨列居中(转)
  7. prim算法适用条件_Prim算法和Kruskal算法介绍
  8. 嵌入式面试C集锦(5) 堆、栈的区别
  9. node基础及模块化
  10. 炫龙毁灭者DD2 UEFI原版WIN10安装Ubantu双系统