detail-8.jpeg
簡述:CoreData是基于SQlite的封裝,直接將OC對象儲存到數據庫中,省去了去寫SQlite語句的煩惱(CoreData是蘋果親兒子喲)
NO.0 CoreData的使用步驟
1.創建模型文件--相當于創建一個數據庫
2.添加實體--相當于表
3.創建實體類--相當于模型類
4.生成上下文,關聯模型文件生成數據庫
5.保存對象到數據庫--增
6.從數據庫獲取對象--查
7.更新數據--改
8.刪除數據--刪
我們會根據以上步驟,簡要介紹一下CoreData的使用
NO.1 創建模型文件
![Uploading CoreData2_649705.png . . .]
新建一個工程,我們有一個需求是創建一個數據庫,里面有個學生表,保存學生的一些信息
1.command + N 我們選擇CoreData 給表取名字
CoreData1.png
給表取名字
CoreData2.png
出現一個文件
CoreData3.png
NO.2 添加實體
1.接下來我們點擊左下角的Add Entity 添加一個表
CoreData4.png
給表取個名字(自己想存什么信息,就取個什么,見名知意)
CoreData5.png
3.在Attributes中給表添加字段及字段類型
CoreData6.png
NO.3 創建實體類--相當于模型類
1.command + N 選擇:
CoreData7.png
2.選擇你創建的數據庫
CoreData8.png
3.選擇你創建的表
CoreData9.png
NO.4.生成上下文,關聯模型文件生成數據庫
#終于到了我們代碼階段,在這之前我們導入一下CoreData的框架和頭文件
#import "ViewController.h"
#import <CoreData/CoreData.h>
#import "Students+CoreDataProperties.h"
@interface ViewController ()
/**上下文*/ 寫成個屬性
@property (nonatomic , strong) NSManagedObjectContext *context;
@end
//關聯上下文的方法
-(void)setUpContext
{
#pragma mark -- 1.上下文 關聯Student.xcdatamodeld 模型文件
//1.創建上下文(導入CoreData框架并導入頭文件)
NSManagedObjectContext *context = [[NSManagedObjectContext alloc]initWithConcurrencyType:NSMainQueueConcurrencyType];
//2.關聯模型文件
//2.1 創建一個模型對象
//傳一個nil,會把 bundle下的所有模型文件關聯起來
NSManagedObjectModel *model = [NSManagedObjectModel mergedModelFromBundles:nil];
//2.2 持久化存儲調度器
NSPersistentStoreCoordinator *store = [[NSPersistentStoreCoordinator alloc]initWithManagedObjectModel:model];
//2.3 存儲數據庫的名字
NSError *error = nil;
//獲得沙盒docment目錄路徑
NSString *docPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject];
//拼接數據庫保存路徑
NSString *sqlitePath = [docPath stringByAppendingPathComponent:@"student.sqlite"];
// NSLog(@"--%@",sqlitePath);
[store addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:[NSURL fileURLWithPath:sqlitePath] options:nil error:&error];
context.persistentStoreCoordinator = store;
self.context = context;
}#不要忘記在viewDidLoad中調用一下這個方法
NO.5 保存對象到數據庫—增
#pragma mark —1. 在storyboard中拖四個按鈕,增刪查改
#增
- (IBAction)addData:(UIButton *)sender {
//創建學生
Students *stu1 = [NSEntityDescription insertNewObjectForEntityForName:@"Students" inManagedObjectContext:self.context];
//給字段寫數據(這里每次點擊增加數據按鈕時,改變一下stu1的屬性值,就存入了不一樣的數據)
stu1.name = @"kobe";
//這里是轉換一下,因為NSNumber是個對象類型
stu1.age = @23;
stu1.height = @132;
//保存 -- 通過上下文操作
NSError *error = nil;
[self.context save:&error];
if (error == nil) {
NSLog(@"插入數據成功");
}else
{
NSLog(@"插入數據失敗");
}
}
NO.6 從數據庫獲取對象—查
#查
- (IBAction)findData:(UIButton *)sender {
//1.創建一個請求對象(并填寫要請求的表名)
NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Students"];
#過濾查詢(根據名字查找jiangjun這個學生)不寫這個過濾條件就會查詢到所有學生的信息
NSPredicate *pre = [NSPredicate predicateWithFormat:@"name = %@",@"jiangjun"];
//我們再限制一下查詢條件:學生的名字是jiangjun,身高要大于180(我保存的是180,所以再次查詢是找不到這個學生的信息的)
// NSPredicate *pre = [NSPredicate predicateWithFormat:@"name = %@ AND height > %@" ,@"jiangjun",@(180)];
request.predicate = pre;
#排序(按照身高排序)--要把上面的過濾查詢注釋掉
//ascending:YES:是按照升序排列(NO為降序)
NSSortDescriptor *sort = [NSSortDescriptor sortDescriptorWithKey:@"height" ascending:YES];
request.sortDescriptors = @[sort];
//2.讀取信息
NSError *error = nil;
//這個方法返回的是一個數組(這個數組其實里面裝的就是學生對象,每一個學生都是一個對象)
NSArray *stu1 = [self.context executeFetchRequest:request error:&error];
if (!error) {//如果查詢成功,我們就打印那個數組
// NSLog(@"--%@",stu1);
//遍歷一下學生對象并打印里面的信息
for (Students *stu in stu1) {
NSLog(@"姓名:%@,年齡:%@,身高:%@",stu.name,stu.age,stu.height);
}
}else
{
NSLog(@"--%@",error);
}
}
NO.7 更新數據—改
#改
- (IBAction)changeData:(UIButton *)sender {
//我把kobe的身高從132改為198
//1.找到kobe
//1.查找到kobe
NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:EntityName];
NSPredicate *pre = [NSPredicate predicateWithFormat:@"name = %@",@"kobe"];
request.predicate = pre;
//2.更新數據
NSArray *stu = [self.context executeFetchRequest:request error:nil];
//不用for遍歷(寫簡單點)
if (stu) {
Students *stu1 = stu[0];
stu1.height = @198;
}
//3.同步數據庫
[self.context save:nil];
}
NO.8 刪除數據—刪
#刪
- (IBAction)cancelData:(UIButton *)sender {
//我們來刪除kobe
//1.查找到kobe
NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:EntityName];//把表名設置為宏了
NSPredicate *pre = [NSPredicate predicateWithFormat:@"name = %@",@"kobe"];
request.predicate = pre;
//2.刪除kobe(因為我們設置了查詢條件,所以這個返回的數組里面只有kobe這個學生對象)
NSArray *stu = [self.context executeFetchRequest:request error:nil];
for (Students *stu1 in stu) {
//調用上下文的方法
[self.context deleteObject:stu1];
}
//3.用context同步一下數據庫
//所有以上的操作都是在內存中進行的,所以調用save同步數據庫
[self.context save:nil];//nil是錯誤信息,我們這里就不看了
}
CoreData 和 Sqlite 簡單對比
- Sqlite 是純C語言存儲數據方式
- coreData 是對Sqlite的封裝,它數據的保存直接面向對象,不用寫Sqlite語句
- 什么情況用Sqlite,什么情況用CoreData
- 數據庫表關聯太復雜,用Sqlite
- 數據庫表結構比較簡單,就只有兩三張表,這些表沒有關聯關系,用CoreData