百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL-计算直播间人气值

wptr33 2024-12-04 16:06 13 浏览


问题描述

直播开播记录表t1有以下字段:

  • 主播id:author
  • 直播间id:live_id
  • 开播时长:live_duration

直播观看记录表t2包含以下字段:

  • 观众id:user_id
  • 直播间id:live_id
  • 观看时长:watching_duration

要求计算直播间的人气值,输出结果格式如下:

主播id

直播间id

ACU

ACU为平均同时在线人数,计算方式为:观众观看时长/某场直播的开播时长,没有人观看的时候显示为0.

模拟数据

# 创建数据库
CREATE DATABASE IF NOT EXISTS demo;
USE demo;

# 开播记录表
DROP TABLE IF EXISTS t1;
CREATE TABLE t1(
	author_id LONG,
	live_id LONG,
	live_duration LONG
);

INSERT INTO t1 VALUES (1, 1, 60), (2,2,120), (3,3,60);

# 观看记录表
DROP TABLE IF EXISTS t2;
CREATE TABLE t2 (
	user_id LONG,
	live_id LONG,
	watching_duration LONG
);

INSERT INTO t2 VALUES (11, 1, 60), (12,1,30), (13, 1, 60),
(12,2,30), (14, 2, 90);

# 计算直播间人气值
SELECT
	t1.author_id, 
	t1.live_id, 
	COALESCE(SUM(t2.watching_duration/t1.live_duration), 0) acu
FROM t1 
LEFT JOIN t2 ON t2.live_id=t1.live_id
GROUP BY 1, 2



打完收工!

相关推荐

文科生自学Python-生成简单的WORD文档

--天行健君子以自强不息,地势坤君子以厚德载物,学习编程成就更好的自己--Python语言简洁生动,特别适合文科生学习入门IT世界,用几十行代码就能够做一个完整的爬虫脚本,开发效率杠杠的!短时间内即可...

使用Python 爬取京东、淘宝等商品详情页的数据,避开反爬虫机制

以下是爬取京东商品详情的Python3代码,以excel存放链接的方式批量爬取。excel如下...

CV学习笔记(二十四):数据集标注与制作

最近在做一些数据标注的工作,虽然标注数据比较枯燥,但这也是每个做算法的工程师升级打怪的必由之路。使用一些合适的工具往往可以事半功倍,效率UP。一:数据标注流程二:数据处理的一些小代码1:重命名当得到这...

新手常见的python报错及解决方案(如何理解python报错信息)

此篇文章整理新手编写代码常见的一些错误,有些错误是粗心的错误,但对于新手而已,会折腾很长时间才搞定,所以在此总结下我遇到的一些问题。希望帮助到刚入门的朋友们。后续会不断补充。...

殊途同归python第5节:一键管理所有文档

Python自带的os模块,文件和文件夹的小管家,直接上代码importosa=os.getcwd()#获取当前路径,以字符串形式返回当前的绝对路径。os.chdir("动画片收...

1.文件夹的处理 OS(文件夹的操作方法)

os.getcwd()#当前目录os.listdir()#列出目录下的文件os.path.join()#拼接路径os.path.split()#拆分路径os.path.exists...

Linux下分析bin文件的10种方法(linux binary文件)

这世界有10种人,一种人懂二进制,另一种人不懂二进制。——鲁迅大家好,我是良许。二进制文件是我们几乎每天都需要打交道的文件类型,但很少人知道他们的工作原理。这里所讲的二进制文件,是指一些可执行文件,...

文科生自学Python-pandas交叉透视表降维变换

--心有猛虎,细嗅蔷薇,学习编程成就更好的自己--...

史上最全!近万字梳理Python 开发必备的 os 模块(建议收藏)

点赞、收藏、加关注,下次找我不迷路...

工作中必备的12个Git命令(常用git命令清单)

...

Undoing a git rebase(undoing a git rebase)

技术背景在使用Git进行版本控制时,gitrebase是一个强大的命令,它可以将一个分支的修改合并到另一个分支,使提交历史更加线性。然而,在某些情况下,我们可能需要撤销...

【干货】常用的Git命令有哪些?(git 常用命令行入门)

Git是一个开源的分布式版本控制系统,它被广泛用于软件开发中。在使用Git进行版本控制时,有许多常用的命令,本文将对这些命令进行详细的介绍。...

项目中使用 husky 格式化代码和校验 commit 信息

大家好,我是前端西瓜哥。今天我们学习使用husky工具,在commit的时候做一些风格的校验工作,包括commit信息格式化和文件格式化。githook和husky...

Git可视化极简易教程 — Git GUI使用方法

前言...

实际工作中 Git Commit 代码提交规范是什么样的?

...