[英]monetdb, group by
在MonetDB中,我有一个“ entrytime”列,其中包含一个时间值。 我有:
select "minute"(entrytime) as unitTime, period
from schema1.zones
where date1 >= eDate and date1 <= xDate and id=256
group by unitTime, period
但是我想将结果分组到15分钟的边界上,然后返回15分钟内最大的“期间”值,有什么想法吗?
谢谢。
这是一个示例R解决方案。 我认为您只需要将您的entrytime列转换为您想要的间隔? 那么您可以使用MAX()运行一个小组?
# run this line once
# install.packages( "MonetDBLite" )
library(DBI)
x <- data.frame( entrytime = sample( 1:1000 , 10000 , replace = TRUE ) , period = sample( 1:10 , 10000 , replace = TRUE ) )
head( x )
x$intervals <- findInterval( x$entrytime , seq( 0 , 1000 , by = 15 ) )
db <- dbConnect( MonetDBLite::MonetDBLite() )
dbWriteTable( db , 'x' , x )
# max period for distinct minutes
head( dbGetQuery( db , "SELECT entrytime , MAX( period ) FROM x GROUP BY entrytime" ) )
# max period for 15 minute intervals
head( dbGetQuery( db , "SELECT intervals , MAX( period ) FROM x GROUP BY intervals" ) )
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.