- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我有一个表格,其中列出了在 sqlite3 数据库中玩过的游戏。 “日期时间”字段是游戏结束时的日期时间。 “持续时间”字段是游戏持续的秒数。我想知道过去 24 小时中至少同时运行 5 场比赛的百分比。我想知道在给定时间运行了多少游戏:
select count(*)
from games
where strftime('%s',datetime)+0 >= 1257173442 and
strftime('%s',datetime)-duration <= 1257173442
如果我有一个表,它只是一个每秒(或每 30 秒或其他时间)的列表,我可以像这样做一个有意的笛卡尔积:
select count(*)
from (
select count(*) as concurrent, d.second
from games g, date d
where strftime('%s',datetime)+0 >= d.second and
strftime('%s',datetime)-duration <= d.second and
d.second >= strftime('%s','now') - 24*60*60 and
d.second <= strftime('%s','now')
group by d.second) x
where concurrent >=5
有没有办法即时创建这个日期表?或者我可以获得与此类似的效果,而不必实际创建一个新表,该表只是本周所有秒数的列表?
谢谢
最佳答案
首先,我想不出一种通过即时创建表格或不借助额外表格来解决您的问题的方法。对不起。
我的建议是您依赖静态 Numbers 表。
创建一个具有以下格式的固定表:
CREATE TABLE Numbers (
number INTEGER PRIMARY KEY
);
用 24 小时中的秒数填充它 (24*60*60 = 84600)。我会使用任何脚本语言通过插入语句来做到这一点:
insert into numbers default values;
现在 Numbers 表中有数字 1 到 84600。您的查询将被修改为:
select count(*)
from (
select count(*) as concurrent, strftime('%s','now') - 84601 + n.number second
from games g, numbers n
where strftime('%s',datetime)+0 >= strftime('%s','now') - 84601 + n.number and
strftime('%s',datetime)-duration <= strftime('%s','now') - 84601 + n.number
group by second) x
where concurrent >=5
我认为,在没有过程语言的情况下,这是你能做到的最好的结果。
关于sqlite3 : Need to Cartesian On date,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1663414/
here它说 选择和交叉产品 叉积是评估成本最高的运营商。如果输入关系具有N和M行,则结果将包含NM行。因此,在应用叉积运算符之前,尽我们最大的努力减小两个操作数的大小非常重要。 假设我们有2个关系
我正在尝试用J复制生命游戏功能的APL代码。搜索“APL中的生命游戏”后,可以找到解释该代码的YouTube视频。目前,我有一个R矩阵,它是: 0 0 0 0 0 0 0 0 0 0 1 1 0 0
我创建了 rdd = sc.parallelize(range(200))。然后我设置 rdd2 = rdd.cartesian(rdd)。我发现 rdd2.count() 正如预期的那样是 40,0
我有一个表格,其中列出了在 sqlite3 数据库中玩过的游戏。 “日期时间”字段是游戏结束时的日期时间。 “持续时间”字段是游戏持续的秒数。我想知道过去 24 小时中至少同时运行 5 场比赛的百分比
我才刚刚开始涉足 Factor .我想计算两个序列的笛卡尔积: { 1 2 3 } { 8 9 } 我想看到的是一系列的序列: { { 1 8 } { 1 9 } { 2 8 } { 2 9 } {
我仍然试图理解为什么我在 Neo4j 中的查询中收到某种格式的笛卡尔积警告,而不是其他格式的警告。这就是我设置数据库的方式: CREATE (q:Form {version: "1.0"}) CREA
我需要将笛卡尔坐标转换为极坐标。我在转换为 polar 时遇到的错误是“Expected type specifier before Polar”。请帮帮我。我阅读了其他帖子,发现我需要指定类类型。我
我试图更好地理解什么是“笛卡尔”。以下是从 xQbert 到 a question I asked earlier 的回答的引用: When working with left (or outer)
这个问题在这里已经有了答案: Expanding tuples into arguments (5 个答案) 关闭 8 个月前。 使用 pythons itertools,我想在一堆列表的所有排列的
我是 Spark 初学者,我面临以下问题:我有一个项目集合(假设它们是笛卡尔坐标或二维点),我想获取每个项目的附近元素。决定一个项目是否靠近另一个取决于一个函数(假设我们想要所有欧几里德距离小于给定值
我想使用 Iterators.jl 计算产品迭代器。假设我有一个具有先验未知大小的 UnitRanges tab 数组。 我想计算 tab 元素的笛卡尔积。 例如,如果标签长度为 2 并且 tab[1
Vulkan使用的坐标系是(-1,-1)位于左上象限,而不是像通常在学校学习的标准笛卡尔坐标系中那样位于左下象限。因此(-1,1)在Vulkan坐标系的左下象限中。 (图片来自:http://vulk
我刚开始使用 Mathematica 时遇到了一个问题。我想更优雅地解决。我有 {x,y,z} 形式的测量数据,想将这些数据转换为特殊坐标。我知道如何使用简单的功能来做到这一点。但是代码变得丑陋。我想
我在 cs::cartesian 中有坐标,我想将它们转换为 WGS84,给定 cs::cartesian 原点的引用坐标。 boost.geometry 可以吗? 最佳答案 我对 Boost.Geo
在 MYSQL 5.6 下,我有以下 2 个表: CREATE TABLE User ( id INTEGER, login VARCHAR(32), i
我真的很想知道,与等效 SQL 查询的笛卡尔积相比,使用 JOIN 是否有任何性能提升。 或者连接只是笛卡尔积的语法糖。 谁能告诉我笛卡尔积和 JOIN 的实现。执行是否明智,两者都需要相同的时间复杂
有一个很好的 C++ 解决方案(实际上是 2 个解决方案:递归和非递归),到 Cartesian Product of a vector of integer vectors .为了说明/简单起见,让
Is there an efficient method to calculate the Cartesian product of two vectors in DolphinDB?在Dolp
Is there an efficient method to calculate the Cartesian product of two vectors in DolphinDB?在Dolp
Is there an efficient method to calculate the Cartesian product of two vectors in DolphinDB?在Dolp
我是一名优秀的程序员,十分优秀!