您的位置:首页 > 数据库

初学Core data笔记

2016-07-09 11:29 302 查看
构成

(1)NSManagedObjectContext

作用:插入数据,查询数据,删除数据

(2)NSManagedObjectModel

数据库所有表格或数据结构,包含各种实体的定义信息

作用:添加实体的属性,建立属性之间的关心

(3)NSPersistentStoreCoordinator

相当于数据库的连接器

作用:设置数据存储的名字,位置,存储方式,和存储时机

(4)NSManagedObject

相当于数据库中的表格记录

快速使用步骤

操作步骤

1、准备工作

新建项目,勾选Use Core Data

打开系统默xxx.xcdatamodeld

创建实体-Entity类似于SQLite中的表

选择Add Entity,建立如下图所示的实体



选择菜单项Editor - Create NSManagedObject SubClasses,勾选所有看到的选项



插入数据代码

-(void)insertCoreData
{
NSManagedObjectContext * context = [self managedObjectContext];
NSManagedObject * person = [NSEntityDescription insertNewObjectForEntityForName:@"Person" inManagedObjectContext:context];
[person setValue:@"jk" forKey:@"name"];
[person setValue:[NSNumber numberWithInt:28] forKey:@"age"];

NSManagedObject * card = [NSEntityDescription insertNewObjectForEntityForName:@"Card" inManagedObjectContext:context];

[card setValue:[NSString stringWithFormat:@"%ld",(NSInteger)[[NSDate date] timeIntervalSince1970]] forKey:@"no"];
[card setValue:person forKey:@"person"];

NSError * error;
if (![context save:&error]) {
NSLog(@"不能保存:%@",[error localizedDescription]);
}
}


查询数据代码

-(void)dataFetchRequest
{
NSManagedObjectContext * context = [self managedObjectContext];
NSFetchRequest * fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription * entity = [NSEntityDescription entityForName:@"Card" inManagedObjectContext:context];
[fetchRequest setEntity:entity];
NSError * error;
NSArray * fetchedObjects = [context executeFetchRequest:fetchRequest error:&error];
for (Card * card in fetchedObjects) {
NSLog(@"no:%@",card.no);
NSLog(@"name:%@",card.person.name);
NSLog(@"age:%@",card.person.age);
}

//    for (NSManagedObject * obj in fetchedObjects) {
//        NSLog(@"no:%@",[obj valueForKey:@"no"]);
//        NSLog(@"name:%@",[[obj valueForKey:@"person"] valueForKey:@"name"]);
//        NSLog(@"age:%@",[[obj valueForKey:@"person"] valueForKey:@"age"]);
//    }
}


先简单写这些。。。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  数据库 存储