今天介绍下iOS数据持久化存储之一:数据库。
苹果为我们提供了抽象化的数据库管理工具CoreData,其本质依旧是生成sqlite文件存储在沙盒目录下,只是封装成对象,免去了我们写sql语句的烦恼,MagicalRecord是一个第三方开源库,封装了系统的CoreData,使代码不再那么晦涩难懂。
一、创建数据库文件 右键New File 创建CoreData DataModel 其实就是一个可视化的数据库
我们起名为StudyMRSqlite 如下图生成了这个StudyMRSqlite.scdatamodeld
二、创建一张表,然后点击左下角的Add Entity 增加一张表 我们给这张表起名为StudyModel
构建表结构 点击Attributes左下角的加号 在这张表中 增加int类型的age和string类型的name两个元素
选择语言 我的工程使用OC所以选择了Objective_C
!!!接下来敲黑板 一定要把StudyModel右侧面板的Codegen改为 Manual/None ,不然你后面create nsmanagerobject subclass时会报重复定义的错误,到时候你肯定还会哭着回来找我
三、创建model文件 Editor——create nsmanagerobject subclass
生成了四个文件 相当于我们的model文件,接下来用到数据库的时候需要引入其中两个.h头文件
可以看到其中就有我们刚才添加的两个属性name和age,
四、在AppDelegate的didFinishLaunchingWithOptions方法里 初始化数据库,并起名为MyRunningDataBase.sqlite 这个初始化方法是创建一个可以数据迁移的数据库,因为我们线上的用户会有一些数据在库中,当我们下个版本改了表结构的时候再次上线需要将老用户的数据迁移到新的表中,这样就不会丢失数据了。
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
//名字为MyRunningDataBase.sqlite 可以数据迁移的数据库 相应的还有其他的初始化方法 可以去查看API
[MagicalRecord setupCoreDataStackWithAutoMigratingSqliteStoreNamed:@"MyRunningDataBase.sqlite"];
NSString *path = [[NSPersistentStore MR_urlForStoreName:@"MyRunningDataBase.sqlite"] absoluteString];
path = [path stringByReplacingOccurrencesOfString:@"%20" withString:@" "];
}
- (void)applicationWillTerminate:(UIApplication *)application {
//关闭数据库
[MagicalRecord cleanUp];
}
在模拟器下运行,打印MyRunningDataBase.sqlite的沙盒路径,点击MAC桌面——前往文件夹进入沙盒,通过沙盒可以看到其本质还是创建.sqlite 文件
打开这个MyRunningDataBase.sqlite文件可以看到如下图所示内容
五、再说说数据迁移Editor —— Add Model Version
使用默认名字StudyMRSqlite 2即可
在右侧面板选择StudyMRSqlite 2为当前版本 这样线上的用户数据就会迁移到新表中
接下来开始上代码
OK 接下来说说MagicalRecord的增删改查
增加数据
StudyModel *student = [StudyModel MR_createEntity];//新建一条记录
student.name = @"张三";
student.age = arc4random()%100 + 1;
[[NSManagedObjectContext MR_defaultContext] MR_saveToPersistentStoreAndWait];//保存数据
查询数据 多种方式查询 用的较多的就是谓词查询
//1.谓词多条件查询 实际应用中用的最多的就是这种 给几个变量 然后查出来符合条件的model排序给一个model数组
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name=%@ && age=%d",@"李四",18];//多条件谓词查询
NSArray *dataArr = [StudyModel MR_findAllSortedBy:@"age" ascending:YES withPredicate:predicate];//按照年龄大小排序
for (StudyModel *student in dataArr)
{
NSLog(@"%@ %lld",student.name,student.age);
}
//2.根据某一条件查询
NSArray *dataArr2 = [StudyModel MR_findByAttribute:@"name" withValue:@"李四"];
for (StudyModel *student in dataArr2)
{
NSLog(@"dataArr2%@ %lld",student.name,student.age);
}
//这张表中所有的数据
NSArray *dataArr3 = [StudyModel MR_findAll];
for (StudyModel *student in dataArr3)
{
NSLog(@"dataArr3%@ %lld",student.name,student.age);
}
改变数据 先根据条件查出来再修改
//根据条件查询出内容然后修改
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name=%@",@"张三",18];//多条件谓词查询
NSArray *dataArr = [StudyModel MR_findAllSortedBy:@"age" ascending:YES withPredicate:predicate];//按照年龄大小排序
for (StudyModel *student in dataArr)
{
student.age = 119;//修改数据
}
[[NSManagedObjectContext MR_defaultContext] MR_saveToPersistentStoreAndWait];//保存数据
删除数据 先根据条件查出来再删除
//1.根据某些条件删除数据
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name=%@ && age=%d",@"张三",18];//多条件谓词查询
NSArray *dataArr = [StudyModel MR_findAllSortedBy:@"age" ascending:YES withPredicate:predicate];//按照年龄大小排序
for (StudyModel *student in dataArr)
{
[student MR_deleteEntity];//删除
}
[[NSManagedObjectContext MR_defaultContext] MR_saveToPersistentStoreAndWait];//保存数据
//删除一张表中所有的数据
[StudyModel MR_truncateAll];
[[NSManagedObjectContext MR_defaultContext] MR_saveToPersistentStoreAndWait];
写了个小Demo 点这里
以上。