CloudKit使用教程<二>

CloudKit使用教程<一>
CloudKit使用教程<二>

CloudKit 基础对象类型

CloudKit 的基础对象类型有 7 种。这些对象类型可能和你在其他编程领域了解的类似对象类型稍有差别。

  • CKContainer: Containers 就像应用运行的沙盒一样,一个应用只能访问自己沙盒中的内容而不能访问其他应用的。Containers 就是最外层容器,每个应用有且仅有一个属于自己的 container。(事实上,经过开发者授权配置 CloudKit Dashboard 之后,一个应用也可以访问其他应用的 container,即共享容器)

  • CKDatabase: Database 即数据库,私有数据库用来存储敏感信息,比如说用户的性别年龄等,用户只能访问自己的私有数据库。应用也有一个公开的数据库来存储公共信息,例如你在构建一个根据地理位置签到的应用,那么地理位置信息就应该存储在公共数据库里以便所有用户都能访问到。

  • CKRecord: 即数据库中的一条数据记录。CloudKit 使用 record 通过 k/v 结构来存储结构化数据。关于键值存储,目前值的架构支持 NSString、NSNumber、NSData、NSDate、CLLocation,和 CKReference、CKAsset(这两个下面我们会说明),以及存储以上数据类型的数组。

  • CKRecordZone: Record 不是以零散的方式存在于 database 之中的,它们位于 record zones 里。每个应用都有一个 default record zone,你也可以有自定义的 record zone。

  • CKRecordIdentifier: 是一条 record 的唯一标识,用于确定该 record 在数据库中的唯一位置。

  • CKReference: Reference 很像 RDBMS 中的引用关系。还是以地理位置签到应用为例,每个地理位置可以包含很多用户在该位置的签到,那么位置与签到之间就形成了这样一种包含式的从属关系。

CKAsset: 即资源文件,例如二进制文件。还是以签到应用为例,用户签到时可能还包含一张照片,那么这张照片就会以 asset 形式存储起来。

可存储的数据类型

  • NSData (single bytes)
  • NSDate (date and time)
  • NSNumber (both Int and Double)
  • NSString (or String in Swift)
  • NSArray (list)
  • CKReference (used to create relationships between objects)
  • CLLocation (location)
  • CKAsset (file)

支持的索引类型:

  • NSString
  • NSDate
  • NSNumber
  • NSArray
  • CKReference
  • CLLocation

如何匹配查询:

%@用于对象的值,%K用于对象的字段

@"self contains 'blue'" 会搜索所有字段对应的值是否包含blue,但是只能搜索字段是NSString类型的.

  • 匹配favoriteColors 有 red 的记录
NSPredicate predicate = nil;
predicate = [NSPredicate predicateWithFormat:@"ANY favoriteColors = 'red'"];
predicate = [NSPredicate predicateWithFormat:@"favoriteColors CONTAINS 'red'"];
predicate = [NSPredicate predicateWithFormat:@"'red' IN favoriteColors"];
predicate = [NSPredicate predicateWithFormat:@"%K CONTAINS %@", @"favoriteColors", @"red"];

  • 同时匹配多个词
NSPredicate predicate = nil;
predicate = [NSPredicate predicateWithFormat:@"ANY { 'red', 'green' } = favoriteColor"];
predicate = [NSPredicate predicateWithFormat:@"favoriteColor IN { 'red', 'green' }"];

  • 匹配以某个字符串开始的记录
NSString* matchString = @"red";
NSPredicate predicate = nil;
predicate = [NSPredicate predicateWithFormat:@"ANY favoriteColors BEGINSWITH 'red'"]
predicate = [NSPredicate predicateWithFormat:@"ANY favoriteColors BEGINSWITH %@", matchString]

  • 匹配当前记录(的所有字段对应的值)是否包含某个字符串
NSPredicate predicate = nil;
predicate = [NSPredicate predicateWithFormat:@"self contains 'bob smith'"];


  • 匹配当前记录(的所有字段对应的值)是否包含多个字符串
NSPredicate predicate = nil;
predicate = [NSPredicate predicateWithFormat:@"self contains 'bob' AND self contains ‘smith’”];

  • 根据地理位置查询
CLLocation* fixedLoc = [[CLLocation alloc] initWithLatitude:37.331913 longitude:-122.030210]; 
CGFloat radius = 10000; // meters
NSPredicate predicate = [NSPredicate predicateWithFormat:@"distanceToLocation:fromLocation:(location, %@) < %f", fixedLoc, radius]];

线程依赖处理

    CKRecordID *firstID = [[CKRecordID alloc] initWithRecordName:@"115"];
    CKRecordID *secondID = [[CKRecordID alloc] initWithRecordName:@"116"];
    
    [public_db fetchRecordWithID:firstID completionHandler:^(CKRecord * _Nullable record, NSError * _Nullable error) {
        
        [public_db fetchRecordWithID:secondID completionHandler:^(CKRecord * _Nullable record, NSError * _Nullable error) {
            
           [public_db saveRecord:record completionHandler:^(CKRecord * _Nullable record, NSError * _Nullable error) {
               
           }];
            
        }];
        
    }];

这些复杂的嵌套行为很容易让你陷入两难:有超过三个(或者更多)的 block 和错误要处理,那么要在哪一层处理哪种错误呢,如果产生了错误,应该在哪一层等待到什么时候重试呢?在这些恼人的嵌套中处理错误和重试,简直就是一场灾难。

幸运的是,苹果给我们提供了NSOperation的子类来管理,使用 NSOperation 的依赖来管理互相依赖的任务.

  • 主要有以下几个类,用法基本与NSOperation一致,非常简单
    CKFetchRecordsOperation;
    CKModifyRecordsOperation;
    CKQueryOperation;
    CKDatabaseOperation;
    CKModifyBadgeOperation;
    CKOperation;
    CKSubscriptionOptions;
    CKModifySubscriptionsOperation;
    CKFetchSubscriptionsOperation;
    
CKFetchRecordsOperation *firstFetchOperateion = [[CKFetchRecordsOperation alloc] init];
    firstFetchOperateion.database = public_db;
    firstFetchOperateion.recordIDs = @[@"115"];
    
    [firstFetchOperateion setFetchRecordsCompletionBlock:^(NSDictionary<CKRecordID *,CKRecord *> *recordsByRecordID, NSError * operationError) {
        if (operationError) {
            NSLog(@"处理错误 - 1");
        }else{
            NSLog(@"success - 1");
        }
    }];
    
    CKFetchRecordsOperation *secondFetchOperateion = [[CKFetchRecordsOperation alloc] init];
    secondFetchOperateion.database = public_db;
    secondFetchOperateion.recordIDs = @[@"116"];
    [secondFetchOperateion setFetchRecordsCompletionBlock:^(NSDictionary<CKRecordID *,CKRecord *> *recordsByRecordID, NSError * operationError) {
        if (operationError) {
            NSLog(@"处理错误 - 2");
        }else{
            NSLog(@"success - 2");
        }
    }];
    
    
    CKRecordID *saveRecordID = [[CKRecordID alloc] initWithRecordName:@"save"];
    CKRecord *saveRecord = [[CKRecord alloc] initWithRecordType:@"Artwork" recordID:saveRecordID];
    
    CKModifyRecordsOperation *modifyOperation = [[CKModifyRecordsOperation alloc] initWithRecordsToSave:@[saveRecord] recordIDsToDelete:nil];
    [modifyOperation setModifyRecordsCompletionBlock:^(NSArray<CKRecord *> *savedRecords , NSArray<CKRecordID *> *deletedRecordIDs, NSError *operationError) {
        //....
        NSLog(@"3333");
    }];


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容