- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下场景:在确定的时间段内可用的给定资源在该时间内花费固定金额。我的用户可以在那段时间访问该资源。我需要在访问它的用户之间分配资源成本,考虑到用户在不访问它的期间不能被收费。像这样的事情:
红色条代表资源在一段时间内的可用性。蓝色和绿色条代表相应用户访问资源的时间。请注意,在时间 9 时,没有人访问该资源,因此没有人付费。考虑到整个时间内的资源成本 $100
,用户 1 将支付 $40
费用,用户 2 将支付 $50
费用。 $10
将丢失。
这种情况的想法很简单:获取资源的全部成本并除以每个用户使用的时间。但是当我们并发使用资源时,问题就会出现:
在本例中,在时间 4 和 5,两个用户都使用相同的资源。在这种情况下,我需要将重叠时间的成本除以 2(并发用户数),得到正确的值。
换句话说:使用该资源的用户越多,每个用户的费用就越便宜。
当然,问题可能会变得更加复杂,如下所示:
目前我有一个具有以下结构的表(使用示例 3):
+---------------------------------------------------------------------------
|ResourceId |UserId |UsageStart |UsageEnd |ResourceTotalCost |WeightedCost |
+--------------------------------------------------------------------------+
|res1 |u1 |time 0 |time 1 |100 |20 |
|res1 |u1 |time 4 |time 7 |100 |40 |
|res1 |u2 |time 4 |time 8 |100 |50 |
|res1 |u3 |time 1 |time 4 |100 |40 |
|res1 |u3 |time 8 |time 8 |100 |10 |
|---------------------------------------------------------------------------
我有每个用户的确切使用时间段,加上资源的总成本(整个分析期间),以及用户的资源加权成本(这是我想要的列)改进)。
UsageStart
和 UsageEnd
列是时间戳,并且具有毫秒精度(这意味着时间可以彼此相隔 1 毫秒)。 ResourceId
和 UserId
是没有模式的字符串(但保证对于每个资源和用户分别是唯一的)。 ResourceTotalCost
和 WeightedCost
都是 float 。
我需要的输出与我已经拥有的输出相同,但加权成本考虑了用户之间资源的并发使用。对于示例 3,这是预期的输出:
+---------------------------------------------------------------------------
|ResourceId |UserId |UsageStart |UsageEnd |ResourceTotalCost |WeightedCost |
+--------------------------------------------------------------------------+
|res1 |u1 |time 0 |time 1 |100 |15 |
|res1 |u1 |time 4 |time 7 |100 |18.33 |
|res1 |u2 |time 4 |time 8 |100 |23.33 |
|res1 |u3 |time 1 |time 4 |100 |28.33 |
|res1 |u3 |time 8 |time 8 |100 |5 |
|---------------------------------------------------------------------------
那么,有什么想法可以解决这个问题吗?我考虑过使用UDF来解决这个问题,但目前 UDF 的使用施加了一些限制(例如同时 6 个 UDF 查询),这是我的项目无法承受的,因此纯 BigQuery SQL 更可取。
谢谢。
最佳答案
尝试以下操作 - 适用于 BigQuery 标准 SQL(请参阅 Enabling Standard SQL 和 Migrating from legacy SQL)
如您所见 - 我稍微调整了您的数据(UsageStart和UsageEnd是整数)
我涉及了您的所有三个示例,ResourceId 分别标记为 res1、res2 和 res3
此外,我还为每个资源添加了额外的条目,以显示资源的可用性。这些条目的 UserId 为 NULL
所以查询是
WITH Usage AS (
SELECT ResourceId, UserId, UsageStart, UsageEnd + 1 AS UsageEnd, ResourceTotalCost
FROM (SELECT 'res3' AS ResourceId, 'u1' AS UserId, 0 AS UsageStart, 1 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res3' AS ResourceId, 'u1' AS UserId, 4 AS UsageStart, 7 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res3' AS ResourceId, 'u2' AS UserId, 4 AS UsageStart, 8 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res3' AS ResourceId, 'u3' AS UserId, 1 AS UsageStart, 4 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res3' AS ResourceId, 'u3' AS UserId, 8 AS UsageStart, 8 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res3' AS ResourceId, NULL AS UserId, 0 AS UsageStart, 9 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res1' AS ResourceId, 'u1' AS UserId, 0 AS UsageStart, 3 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res1' AS ResourceId, 'u2' AS UserId, 4 AS UsageStart, 8 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res1' AS ResourceId, NULL AS UserId, 0 AS UsageStart, 9 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res2' AS ResourceId, 'u1' AS UserId, 0 AS UsageStart, 5 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res2' AS ResourceId, 'u2' AS UserId, 4 AS UsageStart, 8 AS UsageEnd, 100 AS ResourceTotalCost UNION ALL
SELECT 'res2' AS ResourceId, NULL AS UserId, 0 AS UsageStart, 9 AS UsageEnd, 100 AS ResourceTotalCost )
), iIntervals AS (
SELECT ResourceId, iStart, LEAD(iStart)
OVER(PARTITION BY ResourceId ORDER BY iStart) AS iEnd
FROM (
SELECT DISTINCT ResourceId, iStart FROM (
SELECT ResourceId, UsageStart AS iStart FROM Usage UNION ALL
SELECT ResourceId, UsageEnd AS iStart FROM Usage )
)
), iWeights AS (
SELECT iStart, iEnd, x.ResourceId, UserId, ResourceTotalCost,
SUM(iWeight / CASE WHEN Users = 0 THEN 1 ELSE Users END / width) AS iWeight
FROM (
SELECT iStart, iEnd, iEnd - iStart AS iWeight, iIntervals.ResourceId, UserId, ResourceTotalCost,
COUNT(DISTINCT UserId) OVER(PARTITION BY iIntervals.ResourceId, iStart, iEnd) AS Users
FROM iIntervals JOIN Usage
ON iIntervals.ResourceId = Usage.ResourceId
AND iStart >= UsageStart AND iEnd <= UsageEnd
WHERE iEnd IS NOT NULL ) AS x
JOIN (SELECT ResourceId, MAX(iEnd) - MIN(iStart) AS width FROM iIntervals GROUP BY 1) AS y
ON x.ResourceId = y.ResourceId WHERE NOT (UserId IS NULL AND Users > 0) GROUP BY 1, 2, 3, 4, 5
)
SELECT usage.ResourceId, usage.UserId, usage.UsageStart, usage.UsageEnd - 1 as UsageEnd,
iWeights.ResourceTotalCost, ROUND(SUM(iWeights.ResourceTotalCost * iWeight), 2) AS WeightedCost
FROM Usage JOIN iWeights
ON usage.ResourceId = iWeights.ResourceId AND usage.UserId = iWeights.UserId
AND iWeights.iStart BETWEEN usage.UsageStart AND usage.UsageEnd
AND iWeights.iEnd BETWEEN usage.UsageStart AND usage.UsageEnd
GROUP BY 1, 2, 3, 4, 5 ORDER BY 1, 2, 3
输出如下,我认为这是预期的
ResourceId UserId UsageStart UsageEnd ResourceTotalCost WeightedCost
res1 u1 0 3 100 40.0
res1 u2 4 8 100 50.0
res2 u1 0 5 100 50.0
res2 u2 4 8 100 40.0
res3 u1 0 1 100 15.0
res3 u1 4 7 100 18.33
res3 u2 4 8 100 23.33
res3 u3 1 4 100 28.33
res3 u3 8 8 100 5.0
很可能您的UsageStart和UsageEnd不是整数,因此您需要分别调整上述解决方案。但我的重点是为您提供可供处理的可靠逻辑示例。
希望这有帮助!而且它也可能会被优化
关于google-bigquery - 考虑并发使用,在用户之间分配资源成本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40178351/
有人告诉我,如果我只有一个“东西”,比如家(不是多个家),我应该在 routes.rb 中使用资源 :home,而不是资源 :home。但是当我查看路由时,POST 函数似乎想要 home#creat
Activity 开始。这些代码框架顺利通过。 // Initialize array adapters. One for already paired devices and //
资源 search-hadoop.com search-hadoop.com索引所有邮件列表,非常适合历史搜索。当你遇到问题时首先在这里搜索,因为很可能有人已经遇到了你的问题。 邮件列表 在A
我是 WPF 的新手,正在努力使用位于单独程序集中的样式。这就是我正在做的:- 我有一个带有\Themes 文件夹的类库项目,其中包含一个“generic.xaml”,它合并了\Themes 内的子文
我正在编写一个使用虚拟树状文件结构的插件。基本上它就像一个包含文件的标准文件系统,区别在于这些文件实际上并不存在于文件系统中的特定位置,而只是 java 对象。 这些当前由使用 SettingProv
如果我在 XAML 中使用以下内容,我会收到错误消息: 错
我正在使用 laravel 资源来获取 api 的数据: return [ 'id' => $this->id, 'unread' =>
我有以下 pom.xml: 4.0.0 mycompany resource-fail 0.0.1-SNAPSHOT BazBat
许多GDI +类都实现IDisposable,但是我不确定何时应该调用Dispose。对于使用new或静态方法(例如Graphics.CreateGraphics)创建的实例来说,这很明显。但是,由属
我正在构建一组 RESTful 资源,其工作方式如下:(我将使用“people”作为示例): 获取/people/{key} - 返回一个人对象 (JSON) GET/people?first_nam
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一个使用 $resource 的简单 Controller : var Regions = $resource('mocks/regions.json'); $scope.regions =
在 Azure 门户中,如何查看不同资源之间的依赖关系。我特别想查看哪些资源正在使用我要删除的存储。 最佳答案 您可以使用应用程序洞察应用程序 map 来执行此操作: 您还可以打开存储帐户的日志记录:
我正在使用 ionic 生成资源(图标和启动画面)。我正在使用 ionic v2.1.0 和 cordova v6.4.0。 到目前为止我一直在使用(它在以前的版本中工作): cordova plat
是否可以使用 Assets 包含子文件夹中的文件? 示例:[base_url]/assets/css/pepper-grinder/jquery-ui-1.8.11.custom.min.css 最佳
我正在阅读一些尝试教授 Android 开发的书。在书中,作者概述了 res/下的一些目录。他提到 res/menu 包含基于 XML 的菜单规范。他还提到了保存“通用文件”的 res/raw。当我创
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我在服务器上使用 express-resource。在我的 AngularJS Controller 中: var User = $resource('/services/users/:use
因此,每当我运行我的应用程序时,它都会立即崩溃并给出以下错误: No package identifier when getting value for resource number 0x00000
对于我正在创建的(网络)应用程序,我需要使用基本身份验证在我的 UIWebView 中加载页面。 现在设置我使用的授权 header : NSString *result = [NSString st
我是一名优秀的程序员,十分优秀!