最近写的项目中要查找某一个时间戳以后的数据,但是该时间戳是NSNumber类型的。
一:比较NSNumber大小
直接使用谓语的">"比较根本没用.所以想了一个比较取巧的方法,就是使用BETWEEN关键字。
比如我现在要查找在日期"2018-03-18 15:02:00"以后的所有数据.
那么谓语可以写成:
NSString *queryDateStr = @"2018-03-18 15:02:00";
NSDate *queryDate = [formatter dateFromString:queryDateStr];
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"created_time BETWEEN {%@,%@}",[NSNumber numberWithInteger:[queryDate timeIntervalSince1970]],[NSNumber numberWithInteger:[[NSDate date] timeIntervalSince1970]]];
因为数据库中的最新一条数据的时间绝对不会超过查询的当前时间,那么这个谓语一定可以查到在"2018-03-18 15:02:00"之后的所有数据.
但是,有人要问,如果我们要查找一份数据中大于某个值,但是没有上限的NSNumber,应该怎么查找呢?
例如:我现在要查找一些帖子中,评论数大于100的帖子。帖子的评论数在理论上来说是没有上限的,帖子的评论数也是用NSNumber记录的。
predicate = [NSPredicate predicateWithFormat:@"comments BETWEEN {%@,%@}",@100,[NSNumber numberWithInteger:MAXFLOAT]];
直接使用MAXFLOAT就行,同理,上面的Date比较,你也可以把后面的当前时间戳换成MAXFLOAT。
二:排序NSNumber
排序使用系统的sortedArrayUsingComparator当然可以,在block块中转成integerValue进行比较是可以的,但是如果您使用的是Realm这种框架,里面的数组是不支持这个方法的。幸运的是我们可以使用NSSortDescriptor来进行比较.
例如我现在要将这些帖子按评论数排序。
// arr中装有一些NSNumber类型的数据
NSSortDescriptor *descriptor = [NSSortDescriptor sortDescriptorWithKey:@"comments" ascending:YES];
NSArray *sortArr = [arr sortedArrayUsingDescriptors:@[descriptor]];
sortArr就是排序完成的数组了。
三:排序NSString
当NSString存储的是数字类型的时候,也是可以用NSSortDescriptor来进行排序的,原理同上
NSString *user1String = @"1990-03-28 09:34:00";
NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
formatter.dateFormat = @"yyyy-MM-dd HH:mm:ss";
NSDate *user1Date = [formatter dateFromString:user1String];
NSTimeInterval user1TimeInterval = [user1Date timeIntervalSince1970];
NSString *user1TimeStr = [NSString stringWithFormat:@"%lf",user1TimeInterval];
NSString *user2String = @"2000-03-29 09:34:00";
NSDate *user2Date = [formatter dateFromString:user2String];
NSTimeInterval user2TimeInterval = [user2Date timeIntervalSince1970];
NSString *user2TimeStr = [NSString stringWithFormat:@"%lf",user2TimeInterval];
NSString *user3String = @"2018-03-17 09:34:00";
NSDate *user3Date = [formatter dateFromString:user3String];
NSTimeInterval user3TimeInterval = [user3Date timeIntervalSince1970];
NSString *user3TimeStr = [NSString stringWithFormat:@"%lf",user3TimeInterval];
User *user1 = [[User alloc] init];
user1.timeStr = user1TimeStr;
User *user2 = [[User alloc] init];
user2.timeStr = user2TimeStr;
User *user3 = [[User alloc] init];
user3.timeStr = user3TimeStr;
NSArray *arr = @[user1,user2,user3];
NSSortDescriptor *descriptor = [NSSortDescriptor sortDescriptorWithKey:@"timeStr" ascending:YES];
NSArray *newArr = [arr sortedArrayUsingDescriptors:@[descriptor]];
NSLog(@"%@",newArr);
打印结果
"1521250440.000000",
"638588040.000000",
"954293640.000000"
如果您有更好的比较和排序方式,欢迎交流指导☺️