草庐IT

Hive sql 每天场景题 41

吃再多糖也不长胖 2023-04-05 原文

41、现有各直播间的用户访问记录表(live_events)如下,表中每行数据表达的信息为,一个用户何时进入了一个直播间,又在何时离开了该直播间

户访问记录表(live_events)如下

user_id
(用户id)

live_id
(直播间id)

in_datetime
(进入直播间的时间)

out_datetime
(离开直播间的时间)

100

1

2021-12-1 19:30:00

2021-12-1 19:53:00

100

2

2021-12-1 21:01:00

2021-12-1 22:00:00

101

1

2021-12-1 19:05:00

2021-12-1 20:55:00

现要求统计各直播间最大同时在线人数,期望结果如下:

live_id
<int>
(直播id)

max_user_count
<int>
(最大人数)

1

4

2

3

3

2

代码

with t1 as (
-- 时间  动作(登录+1,登出-1)
select
live_id
,in_datetime as check_time
,1 as action
from live_events
union all
select
live_id
,out_datetime as check_time
,-1 as action
from live_events
)

select 
-- 秒级求最大共同人数
live_id
,max(cn) as max_user_count
from (
select 
-- 时间  累加人数 (开窗sum()只要over()中没有partition by 就能实现累加)
live_id
,check_time
,action
,sum(action) over(partition by live_id order by check_time rows between unbounded preceding and current row) as cn
from t1
)a
group by live_id

有关Hive sql 每天场景题 41的更多相关文章

  1. 「Python|Selenium|场景案例」如何定位iframe中的元素? - 2

    本文主要介绍在使用Selenium进行自动化测试或者任务时,对于使用了iframe的页面,如何定位iframe中的元素文章目录场景描述解决方案具体代码场景描述当我们在使用Selenium进行自动化测试的时候,可能会遇到一些界面或者窗体是使用HTML的iframe标签进行承载的。对于iframe中的标签,如果直接查找是无法找到的,会抛出没有找到元素的异常。比如近在咫尺的例子就是,CSDN的登录窗体就是使用的iframe,大家可以尝试通过F12开发者模式查看到的tag_name,class_name,id或者xpath来定位中的页面元素,会抛出NoSuchElementException异常。解决

  2. ruby-on-rails - 使用 Ruby 标准 Logger 每天只创建一个日志 - 2

    我正在使用ruby​​标准记录器,我想要每天轮换一次,所以在我的代码中我有:Logger.new("#{$ROOT_PATH}/log/errors.log",'daily')它运行完美,但它创建了两个文件errors.log.20130217和errors.log.20130217.1。如何强制它每天只创建一个文件? 最佳答案 您的代码对于长时间运行的应用程序是正确的。发生的事情是您在给定的一天多次运行代码。第一次运行时,Ruby会创建一个日志文件“errors.log”。当日期改变时,Ruby将文件重命名为“errors.log

  3. ruby-on-rails - 如何限制模型每天创建一条记录? - 2

    业务逻辑:用户每天只能为日记创建一个条目。在创建条目之前,它必须查询记录以确定是否已经为今天创建了条目。我正在寻找解决此问题的最佳方法的建议。我对如何在客户端实现它有一些想法,但我真的很想在模型层进行验证。任何帮助将不胜感激。 最佳答案 在日志表上创建唯一索引:add_index:journal_entries,[:user_id,:created_on],unique:true然后只能创建一条具有给定user_id和日期的记录,如果违反,数据库将引发异常。请注意,created_on必须是date列,而不是datetime。这是唯

  4. 设计一个亿级高并发系统架构 - 12306火车票核心场景DDD领域建模 - 2

    “架设一个亿级高并发系统,是多数程序员、架构师的工作目标。许多的技术从业人员甚至有时会降薪去寻找这样的机会。但并不是所有人都有机会主导,甚至参与这样一个系统。今天我们用12306火车票购票这样一个业务场景来做DDD领域建模。”开篇要实现软件设计、软件开发在一个统一的思想、统一的节奏下进行,就应该有一个轻量级的框架对开发过程与代码编写做一定的约束。虽然DDD是一个软件开发的方法,而不是具体的技术或框架,但拥有一个轻量级的框架仍然是必要的,为了开发一个支持DDD的框架,首先需要理解DDD的基本概念和核心的组件。一.什么是领域驱动设计(DDD)首先要知道DDD是一种开发理念,核心是维护一个反应领域概

  5. 基于RTS超低延时直播优化强互动场景体验 - 2

    RTS在阿里云视频直播的基础上进行底层技术优化,通过集成阿里云播放器SDK,支持在千万级并发场景下节点间毫秒级延时直播的能力,弥补了传统直播存在3~6秒延时的问题,确保了超低延时、低卡顿、秒开流畅的直播观看体验。本文介绍了基于RTS超低延迟直播优化强互动场景体验的最佳实践方案,并以阿里云播放器Aliplayer为例,详细介绍RTS超低延迟拉流接入、自动降级、排障信息获取等逻辑的实现,助力企业打造互动直播行业的产品竞争力。适用场景该方案适用于对超低延迟直播有诉求的客户,尤其是业务中存在强互动场景直播的场景。强互动场景直播主要是指对主播和观众存在互动,或观众存在更高实时性观看、画面互动需求的情况,

  6. ruby - 如何有条件地跳过 Cucumber 中的场景? - 2

    如何有条件地跳过场景?例如,我希望仅在满足某些条件时才继续一个场景,但我不希望它在不存在时被注册为失败。 最佳答案 这是我遇到的问题。我编写的测试是针对具有不断变化的BE数据库的UI,我目前无法在其中包含静态数据。这意味着有时可能没有测试数据。不是通过也不是失败,只是无法运行。我发现最有效的方法是调用挂起的cucumber。示例测试:Scenario:TesttheapplicationGivenmyapplicationhasdataWhenItestsomethingThenIgetaresult示例步骤定义:Given/^my

  7. ruby-on-rails - cucumber :在 Hook 之前对所有场景只运行一次 - 2

    我有一个包含多个场景的场景大纲。我希望我的BeforeHook只运行一次,这样我就可以引导我需要针对所有场景运行的ActiveRecord对象。问题是如果我使用Beforedo#mycodehereend这将在每个场景之前执行。有没有办法为整个大纲运行一次? 最佳答案 我认为如果您只是在features/support中的文件中创建对象,它们将被持久化:ImportantThing.create(:name=>"USEFULTHING")这是因为在每个ScenarioCucumber之前都会启动一个数据库事务,然后回滚到它之前的状态

  8. ruby - 有没有人想出一种方法来在多个浏览器/网络驱动程序上运行相同的 cucumber 场景? - 2

    我正在使用Cucumber+capybara进行一些网络自动化测试。我希望能够连接我自己的标签(类似于场景之前的@all_browsers)并让它针对我设置的网络驱动程序列表运行(celerity,firefox上的selenium,ie和chrome)。我不想在前面用4个不同的标签写4次不同的场景。我已经研究过尝试使用我通过以下方式注册的新驱动程序来执行此操作:Capybara.register_driver:all_browsersdo|app|#Whatwouldevenworkinhere?Idon'tthinkanythingwill.end然后跟进:Before('@all

  9. ruby - 从 cucumber 步骤中提取场景大纲(或读取标签) - 2

    如果我的场景是这样开始的:@my-tagScenarioOutline:AdminuserchangesemailGivenIregisterarandomemailaddress...是否可以在单个步骤定义中读取场景大纲文本或@my-tag?例如,在Iregisterarandomemailaddress步骤中,如果它在给定场景或标记值下运行,我想打印调试信息。 最佳答案 您不能直接从步骤定义中访问该信息。如果您需要该信息,则必须在beforeHook期间捕获它。cucumberv3+下面的beforehook将捕获特征名称、场景

  10. ruby - 在每天不同的时间设置一个 Whenever 作业 - 2

    我正在尝试设置一个应该每天执行2次的Whenever作业,恰好在上午11点和晚上11点。有没有办法只用一个block来做到这一点?我的意思是这样的:every:day,:at=>['11am','11pm']dorunner"Task"end 最佳答案 Whenever现在支持问题中提出的语法。只需将数组传递给:at选项即可。every:day,at:["11am","11pm"]dorunner"Task"end 关于ruby-在每天不同的时间设置一个Whenever作业,我们在Sta

随机推荐