移动端iOS系统数据库之Realm(一)数据库创建
中文版-通俗版-项目实践版 realm数据使用实践
本文总结realm数据库在iOS开发中遇到的问题以及解决办法,如果您也有遇到更多realm相关的问题请联系我andybbear@163.com
1、realm的使用介绍中文版:https://realm.io/cn/docs/objc/latest/
2、realm的优点介绍
【转】
<code>
跨平台:现在很多应用都是要兼顾iOS和Android两个平台同时开发。如果两个平台都能使用相同的数据库,那就不用考虑内部数据的架构不同,使用Realm提供的API,可以使数据持久化层在两个平台上无差异化的转换。
简单易用:Core Data 和 SQLite 冗余、繁杂的知识和代码足以吓退绝大多数刚入门的开发者,而换用 Realm,则可以极大地减少学习成本,立即学会本地化存储的方法。毫不吹嘘的说,把官方最新文档完整看一遍,就完全可以上手开发了。
可视化:Realm 还提供了一个轻量级的数据库查看工具,在Mac Appstore 可以下载“Realm Browser”这个工具,开发者可以查看数据库当中的内容,执行简单的插入和删除数据的操作。毕竟,很多时候,开发者使用数据库的理由是因为要提供一些所谓的“知识库”。</code>
【自我简单总结】
<code>realm使用简单,和sqlite相比不用使用sql语句,一个model就是一个张表,节省了很大的时间;但是model需要继承RLMObject对象。和CoreData相比的化简化了学习成本,毕竟我从来不用CoreData。从项目使用的角度来说,realm比较好上手,掌握基本的几个方法就能使用,支持事务,数据变化监听,数据迁移,跨平台,对于对数据库要求不高,简单来数据库做缓存的同学来说,使用简单。另一方面,realm使用也有一些坑,例如版本覆盖安装,需要进行版本迁移。pod realm 安装下载比较慢,这一点可以做成静态库放在自己的git上解决。
</code>
3、下面废话少说进入正题,show your code 。
使用pod安装
Podfile写法,指定使用最新版2.8.3
<code>
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '7.0'
target :RealmDemo do
pod 'Realm', '2.8.3'
end
</code>
一、创建数据库
//1、使用默认的realm,会在Documents/下生成一个default.realm文件
<pre><code>
RLMRealm *defaultRealm = [RLMRealm defaultRealm];</pre></code>
//2、自定义路径
<pre>
NSString *rlmPath =[[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject]stringByAppendingString:@"/custom.realm"];
RLMRealm *customRealm = [RLMRealm realmWithURL:[NSURL URLWithString:rlmPath]];
</pre>
//3、通过配置生成realm
<pre>
RLMRealm *configRealm = [RLMRealm realmWithConfiguration:self.config error:nil];
</pre>
4、获取config的方法
<pre>
- (RLMRealmConfiguration *)config {
static RLMRealmConfiguration *_config = nil;
if (!_config) {
RLMRealmConfiguration *config = [[RLMRealmConfiguration alloc] init];
//配置数据迁移的时候,如果有错误导致崩溃问题,会删除数据库重建,不会崩溃,但是数据会丢失。配置NO数据不会丢失,但是应用会崩溃
config.deleteRealmIfMigrationNeeded = YES;
NSString *configPath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject]stringByAppendingString:@"/config.realm"];
config.fileURL = [NSURL URLWithString:configPath];
//设置realm管理的RLMObjects,管理了那么些表,多个数据库表可以分开管理
config.objectClasses = @[NSClassFromString(@"Person"),NSClassFromString(@"Dog")];
_config = config;
}
return _config;
}
</pre>
二、数据迁移
<pre>
//在APP didFinishLaunching调用
+(void)dataBaseMigration {
//如果使用的defualt realm获取默认的config进行迁移
RLMRealmConfiguration *defaultConfig = [RLMRealmConfiguration defaultConfiguration];
//配置数据版本,每次项目发布加1
defaultConfig.schemaVersion = 2;
defaultConfig.migrationBlock = ^(RLMMigration *migration, uint64_t oldSchemaVersion) {
if (oldSchemaVersion < 2) {
//历史版本进行迁移
// [migration enumerateObjects:@"xxx" block:^(RLMObject * _Nullable oldObject, RLMObject * _Nullable newObject) {
//
// }];
}
};
//使用自定义配置的config realm进行迁移
RLMRealmConfiguration *config = self.config;
//配置数据版本,每次项目发布加1
config.schemaVersion = 2;
config.migrationBlock = ^(RLMMigration *migration, uint64_t oldSchemaVersion) {
if (oldSchemaVersion < 2) {
//历史版本进行迁移
// [migration enumerateObjects:@"xxx" block:^(RLMObject * _Nullable oldObject, RLMObject * _Nullable newObject) {
//
// }];
}
};
}
</pre>
三、在Documents下可以找到数据库,
image.png可以用可视化工具打开(在Mac Appstore 可以下载“Realm Browser”这个工具)
下一篇将介绍表的创建和数据的增删改查
代码在这里:https://github.com/icoder20150719/Realm-