• 1661. 每台机器的进程平均运行时间


    SQL架构

    表: Activity

    +----------------+---------+
    | Column Name    | Type    |
    +----------------+---------+
    | machine_id     | int     |
    | process_id     | int     |
    | activity_type  | enum    |
    | timestamp      | float   |
    +----------------+---------+
    该表展示了一家工厂网站的用户活动.
    (machine_id, process_id, activity_type) 是当前表的主键.
    machine_id 是一台机器的ID号.
    process_id 是运行在各机器上的进程ID号.
    activity_type 是枚举类型 ('start', 'end').
    timestamp 是浮点类型,代表当前时间(以秒为单位).
    'start' 代表该进程在这台机器上的开始运行时间戳 , 'end' 代表该进程在这台机器上的终止运行时间戳.
    同一台机器,同一个进程都有一对开始时间戳和结束时间戳,而且开始时间戳永远在结束时间戳前面.

    现在有一个工厂网站由几台机器运行,每台机器上运行着相同数量的进程. 请写出一条SQL计算每台机器各自完成一个进程任务的平均耗时.

    完成一个进程任务的时间指进程的'end' 时间戳 减去 'start' 时间戳. 平均耗时通过计算每台机器上所有进程任务的总耗费时间除以机器上的总进程数量获得.

    结果表必须包含machine_id(机器ID) 和对应的 average time(平均耗时) 别名 processing_time, 且四舍五入保留3位小数.

    以 任意顺序 返回表。

    具体参考例子如下。

    示例 1:

    输入:
    Activity table:
    +------------+------------+---------------+-----------+
    | machine_id | process_id | activity_type | timestamp |
    +------------+------------+---------------+-----------+
    | 0          | 0          | start         | 0.712     |
    | 0          | 0          | end           | 1.520     |
    | 0          | 1          | start         | 3.140     |
    | 0          | 1          | end           | 4.120     |
    | 1          | 0          | start         | 0.550     |
    | 1          | 0          | end           | 1.550     |
    | 1          | 1          | start         | 0.430     |
    | 1          | 1          | end           | 1.420     |
    | 2          | 0          | start         | 4.100     |
    | 2          | 0          | end           | 4.512     |
    | 2          | 1          | start         | 2.500     |
    | 2          | 1          | end           | 5.000     |
    +------------+------------+---------------+-----------+
    输出:
    +------------+-----------------+
    | machine_id | processing_time |
    +------------+-----------------+
    | 0          | 0.894           |
    | 1          | 0.995           |
    | 2          | 1.456           |
    +------------+-----------------+
    解释:
    一共有3台机器,每台机器运行着两个进程.
    机器 0 的平均耗时: ((1.520 - 0.712) + (4.120 - 3.140)) / 2 = 0.894
    机器 1 的平均耗时: ((1.550 - 0.550) + (1.420 - 0.430)) / 2 = 0.995
    机器 2 的平均耗时: ((4.512 - 4.100) + (5.000 - 2.500)) / 2 = 1.456

    max min:

    1. select
    2. machine_id,round(avg(processing_time),3) processing_time
    3. from
    4. (
    5. select
    6. machine_id,process_id,max(timestamp)-min(timestamp) processing_time
    7. from
    8. Activity
    9. group by
    10. machine_id,process_id
    11. ) s1
    12. group by machine_id

    用 if 的技巧:

    1. SELECT
    2. machine_id, round(avg(times) * 2, 3) processing_time # 此时 是 除以了4 所以要 *2
    3. FROM
    4. (SELECT
    5. machine_id, process_id,
    6. IF(activity_type = 'start', round(-`timestamp`, 3), round(`timestamp`, 3)) times
    7. from
    8. Activity
    9. ) t
    10. GROUP BY machine_id;

  • 相关阅读:
    SpringBoot 刷新上下文7--执行BeanFactoryPostProcessor
    Java常用的设计模式,如单例模式、工厂模式、观察者模式等
    JavaWeb前端框架VUE和Element组件详解
    数据仓库建模自动化
    Apache APISIX Ingress v1.5-rc1 发布
    ajax前台提交json与后台的接收
    交换机笔记二
    【Golang】判断数组中是否包含指定元素
    面试题-java实现字符串反转(附:StringBuffer和StringBuilder的区别)
    推送服务本地通知频次及分类管控通知
  • 原文地址:https://blog.csdn.net/m0_69157845/article/details/125534541