我有一个用户事件表。我有用户 ID 和日期。我需要根据日期范围获取用户有事件的季度,即:
日期范围:2011-08-01 - 2012-07-31
Q1 - Aug-Oct
Q2 - Nov-Jan
Q3 - Feb-Apr
Q4 - May-Jul
我玩过 QUARTER mysql 中的函数,但它只返回基于一月作为年初的季度:
SELECT QUARTER(a.Date), a.Date
FROM activity AS a
WHERE a.InstitutionNumber = '000000000075'
AND a.HWA = '001372EADBC4'
AND (a.Date between '2011-08-01' and '2012-07-31')
GROUP BY QUARTER(a.Date), a.HWA
返回:
QUARTER Date
1 2012-01-11
3 2011-08-01
4 2011-10-03
我希望能够在没有重叠的情况下列出每个 HWA 有事件的季度。我的意思是,如果基于 2011 年 8 月至 1012 年 7 月的日期,HWA 在第 1、2 和 3 季度使用,我希望它将该 HWA 列为第 3 个季度。
更新:
从下面的回答中,我现在已经回答了我提出的问题。 我现在更复杂了。一些 HWA 是其他 HWA 的替代品。在这些情况下,它们具有相同的 groupID 以表明它们已链接。在这些情况下,我需要取消重叠的季度。澄清一下,如果两个 HWA 在第 2 季度使用并且它们具有相同的 groupID,那么我只需要计算其中一个的第 2 季度(这无关紧要)。下面是我现在使用的查询和我得到的输出:
SELECT act.HWA, count(act.HWA), m.Status, m.GroupID
FROM (
SELECT
a.HWA, a.Date,
CASE
WHEN MONTH(a.Date) BETWEEN 8 AND 10 THEN 'Q1'
WHEN (MONTH(a.Date) BETWEEN 11 AND 12 OR MONTH(a.Date) = 1) THEN 'Q2'
WHEN MONTH(a.Date) BETWEEN 2 AND 4 THEN 'Q3'
WHEN MONTH(a.Date) BETWEEN 5 AND 7 THEN 'Q4'
END AS quarter,
CASE
WHEN MONTH(a.Date) <= 7 THEN YEAR(a.Date) - 1
ELSE EXTRACT(YEAR_MONTH from a.Date)
END AS quarteryear,
COUNT(*) AS num_activites
FROM activity a
WHERE
a.InstitutionNumber = '000000000075'
AND (a.HWA = '001372EADBC4' OR a.HWA = '180373E241DB' OR a.HWA = '180373E23DE7')
AND (a.Date between '2011-08-01' and '2012-07-31')
GROUP BY
quarter,
a.HWA
) act, machine m
where act.HWA = m.HWA
group by act.HWA
返回这个:
HWA quarters status groupid
001372EADBC4 3 deleted 59970
180373E23DE7 2 online 59970
180373E241DB 1 deleted 59970
这 3 个 HWA 都共享 quarter 3 和相同的 groupID。其中只有一个必须包含 Q3。从上面可以看出,3 个 HWA 总共有 6 个季度。如果您从其中两个中删除第 3 季度,我们总共有 4 个季度用于所有 3 个 HWA,这应该是这样的。任何进一步的帮助都会很棒。
最佳答案
您可以GROUP BY用CASE派生的列按月分隔季度并处理年份,如果月份<=七月,减去1从 year="" 构建从="" 8="" 月开始的="">=七月,减去1从>
SELECT
a.Date,
CASE
WHEN MONTH(a.Date) BETWEEN 8 AND 10 THEN 'Q1'
WHEN (MONTH(a.Date) BETWEEN 11 AND 12 OR MONTH(a.Date) = 1) THEN 'Q2'
WHEN MONTH(a.Date) BETWEEN 2 AND 4 THEN 'Q3'
WHEN MONTH(a.Date) BETWEEN 5 AND 7 THEN 'Q4'
END AS quarter,
CASE
/* Make a year that starts with August so quarters appear to be all in the same year */
WHEN MONTH(a.Date) <= 7 THEN YEAR(a.Date) - 1
ELSE YEAR(a.Date)
END AS quarteryear,
COUNT(*) AS num_activites
FROM Activity a
WHERE
a.InstitutionNumber = '000000000075'
AND a.HWA = '001372EADBC4'
AND (a.Date between '2011-08-01' and '2012-07-31')
/* Groupings over the quarter and fake year for aggregates */
GROUP BY
quarter,
quarteryear
重读你的问题,我意识到这不是你想要的确切输出。以上将为您提供每个季度的事件数,但您真正想要的是有事件的季度数。为此,您可以将上述部分包装在子查询中,并在其上获取 COUNT():
SELECT quarteryear, COUNT(*)
FROM (
SELECT
a.Date,
CASE
WHEN MONTH(a.Date) BETWEEN 8 AND 10 THEN 'Q1'
WHEN (MONTH(a.Date) BETWEEN 11 AND 12 OR MONTH(a.Date) = 1) THEN 'Q2'
WHEN MONTH(a.Date) BETWEEN 2 AND 4 THEN 'Q3'
WHEN MONTH(a.Date) BETWEEN 5 AND 7 THEN 'Q4'
END AS quarter,
CASE
/* Make a year that starts with August so quarters appear to be all in the same year */
WHEN MONTH(a.Date) <= 7 THEN YEAR(a.Date) - 1
ELSE YEAR(a.Date)
END AS quarteryear,
COUNT(*) AS num_activites
FROM Activity a
WHERE
a.InstitutionNumber = '000000000075'
AND a.HWA = '001372EADBC4'
AND (a.Date between '2011-08-01' and '2012-07-31')
/* Groupings over the quarter and fake year for aggregates */
GROUP BY
quarter,
quarteryear
) qtrsubcounts
GROUP BY quarteryear
关于mysql - SQL语句根据日期范围查找季度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11768881/
我想设置一个默认日期,例如实际日期,我该如何设置?还有如何在组合框中设置默认值顺便问一下,date_field_tag和date_field之间有什么区别? 最佳答案 试试这个:将默认日期作为第二个参数传递。youcorrectlysetthedefaultvalueofcomboboxasshowninyourquestion. 关于ruby-on-rails-date_field_tag,如何设置默认日期?[rails上的ruby],我们在StackOverflow上找到一个类似的问
请帮助我理解范围运算符...和..之间的区别,作为Ruby中使用的“触发器”。这是PragmaticProgrammersguidetoRuby中的一个示例:a=(11..20).collect{|i|(i%4==0)..(i%3==0)?i:nil}返回:[nil,12,nil,nil,nil,16,17,18,nil,20]还有:a=(11..20).collect{|i|(i%4==0)...(i%3==0)?i:nil}返回:[nil,12,13,14,15,16,17,18,nil,20] 最佳答案 触发器(又名f/f)是
我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/
我刚刚被困在这个问题上一段时间了。以这个基地为例:moduleTopclassTestendmoduleFooendend稍后,我可以通过这样做在Foo中定义扩展Test的类:moduleTopmoduleFooclassSomeTest但是,如果我尝试通过使用::指定模块来最小化缩进:moduleTop::FooclassFailure这失败了:NameError:uninitializedconstantTop::Foo::Test这是一个错误,还是仅仅是Ruby解析变量名的方式的逻辑结果? 最佳答案 Isthisabug,or
这个问题在这里已经有了答案:Railsformattingdate(4个答案)关闭4年前。我想格式化Time.Now函数以显示YYYY-MM-DDHH:MM:SS而不是:“2018-03-0909:47:19+0000”该函数需要放在时间中.现在功能。require‘roo’require‘roo-xls’require‘byebug’file_name=ARGV.first||“Template.xlsx”excel_file=Roo::Spreadsheet.open(“./#{file_name}“,extension::xlsx)xml=Nokogiri::XML::Build
我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s
假设我有这个范围:("aaaaa".."zzzzz")如何在不事先/每次生成整个项目的情况下从范围中获取第N个项目? 最佳答案 一种快速简便的方法:("aaaaa".."zzzzz").first(42).last#==>"aaabp"如果出于某种原因你不得不一遍又一遍地这样做,或者如果你需要避免为前N个元素构建中间数组,你可以这样写:moduleEnumerabledefskip(n)returnto_enum:skip,nunlessblock_given?each_with_indexdo|item,index|yieldit