我想获取最接近过去或 future 特定日期的数据,以较接近该日期的日期为准。但我还需要它通过 type 来distinct。例如:
id |type |data | date
1 |0 |1904 |2018-08-19 00:14:32
2 |0 |1904 |2018-08-19 00:24:47
3 |0 |1904 |2018-08-19 05:02:30
4 |0 |1904 |2018-08-22 00:05:58
5 |0 |1904 |2018-08-22 00:08:34
6 |4 |1903 |2018-08-19 00:14:31
7 |6 |1926 |2018-08-19 00:14:32
8 |6 |1926 |2018-08-19 04:44:10
9 |6 |1926 |2018-08-19 04:52:58
10 |6 |1926 |2018-08-19 04:59:23
11 |6 |1926 |2018-08-22 00:05:58
12 |6 |1926 |2018-08-22 00:07:52
13 |6 |1926 |2018-08-22 00:08:34
14 |7 |1564 |2018-08-19 00:14:32
15 |8 |1900 |2018-08-19 00:14:32
如果我指定日期时间:2018-08-19 00:00:00。我应该得到以下结果:
id | type
1 | 0
6 | 4
7 | 6
14 | 7
15 | 8
或者如果我指定日期时间:2018-09-03 00:00:00。我希望:
id | type
5 | 0
6 | 4
13 | 6
14 | 7
15 | 8
或者最后:2018-08-22 00:05:58。
id | type
4 | 0
6 | 4
11 | 6
14 | 7
15 | 8
我尝试了一些没有真正意义的查询......比如:
SELECT *
FROM history
WHERE (ABS(TIMESTAMPDIFF(DAY, date, "2018-08-19 00:08:34")) < 4) AND user_id = 1299
GROUP BY type
ORDER BY date
无论如何,单独使用 MySQL 查询是否可行?我是否需要使用一些应用程序逻辑来完成此操作?我该如何查询?
最佳答案
这采用标准查询模式来查找每种类型具有极值的行。在这种情况下,极端 表示最接近目标值。
首先,您需要一个聚合子查询来获取极值:每种类型的行与您的目标日期之间的最小增量时间。 ( http://sqlfiddle.com/#!9/b51a7a/26/1 )
SET @target := '2018-08-20 00:00:00';
SELECT type, MIN(ABS(TIMESTAMPDIFF(MINUTE, date, @target))) delta
FROM history
GROUP BY type
然后使用 ON 子句将其连接到原始表以匹配类型和增量时间。将它们放在一起(http://sqlfiddle.com/#!9/b51a7a/27/1)
SET @target := '2018-08-20 00:00:00';
SELECT history.*
FROM history
JOIN (
SELECT type, MIN(ABS(TIMESTAMPDIFF(MINUTE, date, @target))) delta
FROM history
GROUP BY type
) delta ON history.type=delta.type
AND ABS(TIMESTAMPDIFF(MINUTE, date, @target)) = delta
编辑 仅获取最近的 future 或最近的过去项目更容易。子查询(最近的过去)是
SELECT type, MAX(date) date
FROM history
WHERE date <= @target
GROUP BY date
那么整体查询就是
SELECT history.*
FROM history
JOIN (
SELECT type, MAX(date) date
FROM history
WHERE date <= @target
GROUP BY date
) m ON history.type = m.type AND history.date = m.date
关于mysql - 从最接近所选日期的数据库中获取唯一数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52139056/
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?
我想设置一个默认日期,例如实际日期,我该如何设置?还有如何在组合框中设置默认值顺便问一下,date_field_tag和date_field之间有什么区别? 最佳答案 试试这个:将默认日期作为第二个参数传递。youcorrectlysetthedefaultvalueofcomboboxasshowninyourquestion. 关于ruby-on-rails-date_field_tag,如何设置默认日期?[rails上的ruby],我们在StackOverflow上找到一个类似的问
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
有没有办法在这个简单的get方法中添加超时选项?我正在使用法拉第3.3。Faraday.get(url)四处寻找,我只能先发起连接后应用超时选项,然后应用超时选项。或者有什么简单的方法?这就是我现在正在做的:conn=Faraday.newresponse=conn.getdo|req|req.urlurlreq.options.timeout=2#2secondsend 最佳答案 试试这个:conn=Faraday.newdo|conn|conn.options.timeout=20endresponse=conn.get(url
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳
我有一个存储主机名的Ruby数组server_names。如果我打印出来,它看起来像这样:["hostname.abc.com","hostname2.abc.com","hostname3.abc.com"]相当标准。我想要做的是获取这些服务器的IP(可能将它们存储在另一个变量中)。看起来IPSocket类可以做到这一点,但我不确定如何使用IPSocket类遍历它。如果它只是尝试像这样打印出IP:server_names.eachdo|name|IPSocket::getaddress(name)pnameend它提示我没有提供服务器名称。这是语法问题还是我没有正确使用类?输出:ge
我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c
这个问题在这里已经有了答案: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