最近寫(xiě)的項(xiàng)目中要查找某一個(gè)時(shí)間戳以后的數(shù)據(jù),但是該時(shí)間戳是NSNumber類(lèi)型的。
一:比較NSNumber大小
直接使用謂語(yǔ)的">"比較根本沒(méi)用.所以想了一個(gè)比較取巧的方法,就是使用BETWEEN關(guān)鍵字。
比如我現(xiàn)在要查找在日期"2018-03-18 15:02:00"以后的所有數(shù)據(jù).
那么謂語(yǔ)可以寫(xiě)成:
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]]];
因?yàn)閿?shù)據(jù)庫(kù)中的最新一條數(shù)據(jù)的時(shí)間絕對(duì)不會(huì)超過(guò)查詢(xún)的當(dāng)前時(shí)間,那么這個(gè)謂語(yǔ)一定可以查到在"2018-03-18 15:02:00"之后的所有數(shù)據(jù).
但是,有人要問(wèn),如果我們要查找一份數(shù)據(jù)中大于某個(gè)值,但是沒(méi)有上限的NSNumber,應(yīng)該怎么查找呢?
例如:我現(xiàn)在要查找一些帖子中,評(píng)論數(shù)大于100的帖子。帖子的評(píng)論數(shù)在理論上來(lái)說(shuō)是沒(méi)有上限的,帖子的評(píng)論數(shù)也是用NSNumber記錄的。
predicate = [NSPredicate predicateWithFormat:@"comments BETWEEN {%@,%@}",@100,[NSNumber numberWithInteger:MAXFLOAT]];
直接使用MAXFLOAT就行,同理,上面的Date比較,你也可以把后面的當(dāng)前時(shí)間戳換成MAXFLOAT。
二:排序NSNumber
排序使用系統(tǒng)的sortedArrayUsingComparator當(dāng)然可以,在block塊中轉(zhuǎn)成integerValue進(jìn)行比較是可以的,但是如果您使用的是Realm這種框架,里面的數(shù)組是不支持這個(gè)方法的。幸運(yùn)的是我們可以使用NSSortDescriptor來(lái)進(jìn)行比較.
例如我現(xiàn)在要將這些帖子按評(píng)論數(shù)排序。
// arr中裝有一些NSNumber類(lèi)型的數(shù)據(jù)
NSSortDescriptor *descriptor = [NSSortDescriptor sortDescriptorWithKey:@"comments" ascending:YES];
NSArray *sortArr = [arr sortedArrayUsingDescriptors:@[descriptor]];
sortArr就是排序完成的數(shù)組了。
三:排序NSString
當(dāng)NSString存儲(chǔ)的是數(shù)字類(lèi)型的時(shí)候,也是可以用NSSortDescriptor來(lái)進(jìn)行排序的,原理同上
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);
打印結(jié)果
"1521250440.000000",
"638588040.000000",
"954293640.000000"
如果您有更好的比較和排序方式,歡迎交流指導(dǎo)??