我有一个数据库表并存储一个包含 UTC 日期时间的日期时间列,iOS [NSDate date] 始终返回 UTC 日期时间。这一切都很好。
我使用 FMDB 通过以下代码获取最近 12 小时和 24 小时的数据。
[self.fmQueue inDatabase:^(FMDatabase *db)
{
NSString* queryCommand = [NSString stringWithFormat:@"SELECT * FROM %@ WHERE %@ >= Datetime('?')", readingsTable, dateTimeRecordedColumn];
NSDate* dateBefore24Hours = [self.dateUtilities dateBySubtractingDays:1 forDate:[NSDate date]];
WEELogDebug(@"Date before 24 hours: %@", dateBefore24Hours);
FMResultSet* result = [db executeQuery:queryCommand, dateBefore24Hours];
if (completionblock)
{
completionblock([self readingsArrayFromResultSet:result]);
}
}];
我需要完成的是检索在 dateBefore24Hours
变量之后具有日期的所有数据。调试消息显示正确的值,例如[NSDate date] now before 24 hours is, Date before 24 hours: 2015-04-06 15:28:08 +0000
,所以我应该得到 al使用上述查询,直到 2015-04-07 15:28:08 +0000
为止的记录,但我没有。
通过 SQLite Studio,我向您提供我目前在数据库中拥有的记录。
最佳答案
您不需要 Datetime()
函数。 (即使您这样做了,也永远不会将 ?
放在引号内。)
当 FMDB 在参数列表中遇到 NSDate
对象时,它会自动执行 timeZoneForSecondsFromGMT
(如果您没有指定 dateFormat
string),因此在与 dateTimeRecorded
列进行比较时可以使用日期的数字表示形式。顺便说一句,这个数值可以在 SQLite 中作为 unixepoch
值进行访问。
底线,您应该能够使用?
:
SELECT * FROM %@ WHERE %@ >= ?
关于ios - SQLite Datetime 24小时前查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29495367/