gpt4 book ai didi

ios - SQLite Datetime 24小时前查询

转载 作者:行者123 更新时间:2023-11-29 02:08:50 27 4
gpt4 key购买 nike

我有一个数据库表并存储一个包含 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,我向您提供我目前在数据库中拥有的记录。

Records in SQLite

最佳答案

您不需要 Datetime() 函数。 (即使您这样做了,也永远不会将 ? 放在引号内。)

当 FMDB 在参数列表中遇到 NSDate 对象时,它会自动执行 timeZoneForSecondsFromGMT (如果您没有指定 dateFormat string),因此在与 dateTimeRecorded 列进行比较时可以使用日期的数字表示形式。顺便说一句,这个数值可以在 SQLite 中作为 unixepoch 值进行访问。

底线,您应该能够使用:

SELECT * FROM %@ WHERE %@ >= ?

关于ios - SQLite Datetime 24小时前查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29495367/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com