我有一个表格,其中列出了在 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/
出于某种原因,heroku尝试要求dm-sqlite-adapter,即使它应该在这里使用Postgres。请注意,这发生在我打开任何URL时-而不是在gitpush本身期间。我构建了一个默认的Facebook应用程序。gem文件:source:gemcuttergem"foreman"gem"sinatra"gem"mogli"gem"json"gem"httparty"gem"thin"gem"data_mapper"gem"heroku"group:productiondogem"pg"gem"dm-postgres-adapter"endgroup:development,:t
我是Sinatra的新手,我正在尝试使用SQLite3和Datamapper创建一个数据库。我安装了gem和适配器,然后尝试在文件中执行此代码:#configrequire'sinatra'require'sinatra/contrib'ifdevelopment?require'data_mapper'DataMapper::setup(:default,"sqlite3://#{Dir.pwd}/recall.db")DataMapper.finalize.auto_upgrade!当我执行文件时,命令行给了我这个错误:C:/Ruby193/lib/ruby/site_ruby/1
我正在试用rvm,并用它安装了ruby1.9.2和rails3。我需要重新安装sqlite3-rubygem(因为rvm为不同版本的ruby将所有gem分开)。问题是,当我尝试时,我得到:geminstallsqlite3-ruby/home/jenny/.rvm/rubies/ruby-1.9.2-p0/bin/gem:4:warning:Insecureworldwritabledir/home/jenny/.rvm/gems/ruby-1.9.2-p0/bininPATH,mode040777Buildingnativeextensions.Thiscouldtakeaw
我正在关注RubyonRailsTutorial并且在测试部分变得有些困惑,特别是-3.6.2-AutomatedtestswithGuard按照部署到Heroku的教程说明,我已切换到Postgresql并从我的gemfile中删除了sqlite3,并进行了捆绑安装以进行更新。但是,一旦我运行bundleexecguard我收到消息:/Users/username/.rvm/gems/ruby-1.9.3-p125@global/gems/bundler-1.1.3/lib/bundler/rubygems_integration.rb:147:inblockinreplace_ge
我在crunchbanglinux上安装sqlite3-rubygem时遇到问题。在谷歌搜索过去几个小时并关注了几个遇到同样问题的人之后,我仍然没有让它工作。这是我在尝试“sudogeminstallsqlite3-ruby”后看到的构建native扩展。这可能需要一段时间...错误:安装sqlite3-ruby时出错:错误:无法构建gemnative扩展。/usr/bin/ruby1.8extconf.rb检查sqlite3.h...是的在-lsqlite3中检查sqlite3_libversion_number()...是检查rb_proc_arity()...否检查sqlite3
嗨,这么多天以来,我一直在搜索这个主题,但也无法得到提示。如果有人知道如何使用cordova和javascript将sqlite数据同步到sqlserver,请帮忙 最佳答案 开源实现有一些开源项目可以将PhoneGap应用程序与远程服务器同步。但是您必须调整/实现以适合您的项目。SynchronizealocalWebSQLDbtoaserverCouchbaseLitePhoneGappluginPouchdb或者,自定义API您可以创建自己的API方法集,以将数据从WebSQL发送/更新到您的远程服务器DB。标记需要“同步”到
连接SQLite数据库对于as内部模拟器可以使用AppInspection,支持API26版本以上优点:这种是最方便的可以实时查看数据表的变化缺点:仅支持内部模拟器,需要安装的东西比较多,很慢,机器性能不好很卡顿对于第三方模拟器可以通过DeviceFileExplorer找到app的.db文件进行查看.db生成位置和名称需要配置来判断litepal.xml-->-->-->-->.db文件在模拟器中的位置需要安装插件,或者其他软件查看数据,不能实时查询具体方法是找到.db文件双击会在电脑的磁盘上生成一个复制的文件(或者直接从模拟器文件夹中将文件复制出来),此时通过DatabaseNavigat
关闭。这个问题是notreproducibleorwascausedbytypos.它目前不接受答案。这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topic在这里,这个问题的解决方式不太可能帮助future的读者。关闭3年前。Improvethisquestion我试图将Go中的错误转换为go-sqlite3.Error,但它总是失败。上图代表我的调试窗口的快照,它显示错误是go-sqlite3.Error类型我正在使用下面的代码进行类型转换。import("github.com/mattn/go-sqlite3")iferr!=nil{ifsqlite3E
我目前正在使用mattn的go-sqlite3包,并希望使用LIKE'%word%'条件进行许多选择语句搜索。mattn的正则表达式扩展是否比sqlite内置的LIKE运算符更快?(更具体地针对LIKE'%word%'搜索) 最佳答案 mattn/go-sqlite3项目本身已经有相当多的例子SELECTbenchmarksfuncBenchmarkRows(b*testing.B){db.once.Do(makeBench)forn:=0;n您可以根据您的特定测试调整它们。 关于sql
我试图在go中实现一个需要连接到sqlite数据库的函数。这个数据库有多个模型,上级建议我使用gorm库。程序似乎按名称检测我试图访问的表,但它总是返回零值(数字属性)或空字符串。我的第一次尝试是用结构标记来建模模式,但是这是我第一次遇到问题。然后我尝试使用'db'preffix来使用struct标记,指定sqlite中每个属性的名称,但没有任何更改。之后,我用'sql'前缀应用了struct标记…又一次什么都没发生,也有同样的问题。作为最后一次尝试,我将prefix改为“gorm”,但问题又出现了。之后,我删除了所有的struct标记,只留下了对应于主键(id)的struct标记。我