求教 | SQL的count()函数里居然能加两个参数
学习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()函数里居然能加两个参数相关推荐
- hibernate SQL查询COUNT函数
在Oracle11g中hibernate执行SQL语句使用COUNT聚合函数时,返回类型是BigDecimal 在MySQL5.5中COUNT聚合函数返回类型则是BigInteger 用其他类型数据接 ...
- SQL中count和case when结合使用统计某个条件下不重复的记录数
目录 一.统计某一种类型的不重复的个数 二.分组后再统计某一种类型的不重复的个数 三.分组后统计汇总的数据和某一种类型的不重复的个数 最近遇到一个问题,需要分组统计某种类型的金额总和跟该类型的记录数 ...
- Oracle count函数原理,oracle count函数
用来返回查询的行数. 当指定distinct时,不能接order_by_clause: 如果指定表达式,count返回表达式不为空的值: 当指定*号时,它返回所有行,含重复行和空值.count从不返回 ...
- mysql数据库中count的作用_详解 MySQL中count函数的正确使用方法
1. 描述 在MySQL中,当我们需要获取某张表中的总行数时,一般会选择使用下面的语句 select count(*) from table; 其实count函数中除了*还可以放其他参数,比如常数.主 ...
- pythonint函数的参数_向嵌入的Python函数传递两个参数(int和array)
我需要从我的模块中调用Python函数并为其设置两个参数:int和array.在 现在我在调用这个函数的时候遇到了segfault,我不知道我做错了什么.有人能指出我的错误在哪里吗?在 函数在我的Py ...
- C程序设计基础(5):函数基础详解(函数定义、调用、原型、参数)
上一节中,我们学习了有关数组和字符串的常用方法.数组和字符串的加持大大降低了我们命名和使用变量的复杂程度,节约了代码量,但这还不够.程序编写过程中,我们往往会遇到一段相似的代码在多个不同的位置出现 ...
- R语言使用choose函数计算排列组合:组合数(输入两个参数、combination)
R语言使用choose函数计算排列组合:组合数(输入两个参数.combination) 目录 R语言使用choose函数计算组合数(输入两个参数.combination) R 语言特点 R语言使用ch ...
- T-SQL里数据库工程师都不知道的秘密之SQL Server自定义函数UDF
T-SQL SQL Server UDF自定义函数概念与案例实战 函数的定义 这里的函数指的是用户自定义函数(UDF)全名为(user-defined function),以下简称为函数. 它是数据库 ...
- 【3 - 查询】Sql Server - 郝斌(计算列、distinct、between、in、top、null、order by、模糊查询、聚合函数[主要是count()函数] )
课程地址:数据库 SQLServer 视频教程全集(99P)| 22 小时从入门到精通_哔哩哔哩_bilibili 目录 查询(最重要,难度最大) (一)大纲 (二)Scott 表 下载与导入SQ ...
最新文章
- Ubuntu安装deb软件包错误(依赖关系问题)解决
- java打地鼠游戏-有背景音乐有图
- 关于C语言的一些小知识点
- BZOJ 2440 完全平方数(莫比乌斯-容斥原理)
- python代码进去docker容器内_python脚本监控docker容器
- Python数据挖掘和机器学习
- linux 如何加密文件夹,如何加密个别文件夹?
- 房屋租赁合同可不可以用笔修改
- cnpm和npm使用,遇到的问题及解决方法
- MySQL 中文字段排序问题(根据中文拼音排序)
- Halcon椭圆测量
- 美大联盟中国小将3年年薪翻60倍 从第7前锋到赢新合同
- 洛谷 P1878 舞蹈课 —— 小顶堆
- elasticsearch的.security-7索引崩溃恢复笔记
- QQ群名片尾巴生成原理
- html文档中的元素分为两部分,云开HTML5开发基础与应用(20秋)形考作业2【标准答案】...
- 程序员锻炼腰部几个简单的方法
- ElasticSearch基础:从倒排索引说起,快速认知ES
- 到底多少够用 11款USB设备供电大揭秘
- 甲骨文助ISV 通过SOA与Oracle软件集成
热门文章
- [分享]关于mac的保修时间计算政策,附送延长保修时间秘诀
- 孤独匠人说:给我500万三年超马云
- Dejavu Sans Mono字体使用指南
- 魅族18双击亮屏图文设置方法(2021)
- “遯世无闷”与“人不知不愠”
- Excel动画图解:Excel标题跨列居中(转)
- prim算法适用条件_Prim算法和Kruskal算法介绍
- 嵌入式面试C集锦(5) 堆、栈的区别
- node基础及模块化
- 炫龙毁灭者DD2 UEFI原版WIN10安装Ubantu双系统