基于iOS Realm数据库的使用实例详解

首先下载Realm源代码,https://realm.io/cn/docs/objc/latest

将下载的文件解压,从 ios/static/ 目录中将 Realm.framework 拖曳到 Xcode 工程的文件导航器内,然后在 Xcode 文件导航器中选中工程。然后选择应用目标,前往 Build Phases 选项卡。在 Link Binary with Libraries 部分中单击 + 按钮,然后添加 libc++.tbd 和 libz.tbd。这样还没有完,我们还需要安装插件,打开解压文件夹下的plugin,运行RealmPlugin.xcodeproj,然后重启XCode。

这样环境配置就完了,现在说重点如何去使用。

1.创建实体类

new File翻到最下面点击创建Realm实体类

#import <Realm/Realm.h>
@interface TestBean : RLMObject
@property NSString* name;
@property NSInteger age;

@end
// This protocol enables typed collections. i.e.:
// RLMArray<TestBean *><TestBean>
RLM_ARRAY_TYPE(TestBean)
#import "TestBean.h"
@implementation TestBean

@end

2.增删改查

这个增加,可以看到直接添加实体类就行了,这个RLMRealm就是数据库的操作类,以后所有操作都靠他。

-(void)addAction{
 NSLog(@"add");
 self.name = _tf_name.text;
 self.age = [_tf_age.text integerValue];

 TestBean* bean = [[TestBean alloc]init];
 bean.name = self.name;
 bean.age = self.age;
 RLMRealm *realm = [RLMRealm defaultRealm];
 [realm transactionWithBlock:^{
  [realm addObject:bean];
 }];

}

删除也是通过删除实体类来实现,但是我们需要首先通过查询出实体类才行。这个查询我们可以看到通过我们创建的实体类就能实现

-(void)deleteAction{

 NSLog(@"delete");
 RLMResults *dogs = [TestBean allObjects];
 RLMRealm *realm = [RLMRealm defaultRealm];
 [realm transactionWithBlock:^{
  for (TestBean *bean in dogs) {
   [realm deleteObject:bean];
  }
 }];
}

更新也是通过改变实体类的数据来实现

-(void)updateAction{
 NSLog(@"update");
 RLMResults *dogs = [TestBean allObjects];
 [[RLMRealm defaultRealm] transactionWithBlock:^{
  for (TestBean *bean in dogs) {
   bean.name = @"李四";
  }
 }];
}

查询我们还可以添加条件

// 使用断言字符串来查询
RLMResults<Dog *> *tanDogs = [Dog objectsWhere:@"color = 'tan' AND name BEGINSWITH 'B'"];
// 使用 NSPredicate 来查询
NSPredicate *pred = [NSPredicate predicateWithFormat:@"color = %@ AND name BEGINSWITH %@",
              @"tan", @"B"];
tanDogs = [Dog objectsWithPredicate:pred];

3.排序

这个是在查询完后去实现,通过实体类的key来排序。

-(void)sortAction{
 NSLog(@"query");
 RLMResults *dogs = [[TestBean allObjects] sortedResultsUsingKeyPath:@"name" ascending:YES];
 [[RLMRealm defaultRealm] transactionWithBlock:^{
  for (TestBean *bean in dogs) {
   NSLog(@"%@",bean.name);
  }
 }];

}

4.小结

只说了常用的功能,贴上官方中文文档供大家参考

https://realm.io/cn/docs/objc/latest

5.例子代码

//
// ViewController.m
// BmobTest
//
// Created by shanreal-iOS on 2017/12/9.
// Copyright © 2017年 shanreal.LongZhenHao. All rights reserved.
//
#import "ViewController.h"
#import "TestBean.h"
@interface ViewController ()
@property(nonatomic,strong)UIButton* add;
@property(nonatomic,strong)UIButton* delete;
@property(nonatomic,strong)UIButton* update;
@property(nonatomic,strong)UIButton* query;
@property(nonatomic,strong)UIButton* sort;

@property(nonatomic,strong)NSString* name;
@property(nonatomic,assign)NSInteger* age;
@property(nonatomic,strong)UITextField* tf_name;
@property(nonatomic,strong)UITextField* tf_age;
@end
@implementation ViewController
- (void)viewDidLoad {
 [super viewDidLoad];
 // Do any additional setup after loading the view, typically from a nib.

 _add = [[UIButton alloc]initWithFrame:CGRectMake(10, 30, 100, 20)];
 [_add setTitle:@"add" forState:UIControlStateNormal];
 [_add setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
 [_add addTarget:self action:@selector(addAction) forControlEvents:UIControlEventTouchUpInside];
 _delete = [[UIButton alloc]initWithFrame:CGRectMake(10, 60, 100, 20)];
 [_delete setTitle:@"delete" forState:UIControlStateNormal];
 [_delete setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
 [_delete addTarget:self action:@selector(deleteAction) forControlEvents:UIControlEventTouchUpInside];
 _update = [[UIButton alloc]initWithFrame:CGRectMake(10, 90, 100, 20)];
 [_update setTitle:@"update" forState:UIControlStateNormal];
 [_update setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
 [_update addTarget:self action:@selector(updateAction) forControlEvents:UIControlEventTouchUpInside];

 _query = [[UIButton alloc]initWithFrame:CGRectMake(10, 120, 100, 20)];
 [_query setTitle:@"query" forState:UIControlStateNormal];
 [_query setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
 [_query addTarget:self action:@selector(queryAction) forControlEvents:UIControlEventTouchUpInside];
 _sort = [[UIButton alloc]initWithFrame:CGRectMake(10, 150, 100, 20)];
 [_sort setTitle:@"sort" forState:UIControlStateNormal];
 [_sort setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
 [_sort addTarget:self action:@selector(sortAction) forControlEvents:UIControlEventTouchUpInside];

 _tf_name = [[UITextField alloc]initWithFrame:CGRectMake(50, 300, 200, 20)];
 _tf_name.placeholder=@"name";
 _tf_age = [[UITextField alloc]initWithFrame:CGRectMake(50, 350, 200, 20)];
 _tf_age.placeholder=@"age";
 [self.view addSubview:_add];
 [self.view addSubview:_delete];
 [self.view addSubview:_update];
 [self.view addSubview:_query];
 [self.view addSubview:_sort];
 [self.view addSubview:_tf_name];
 [self.view addSubview:_tf_age];
}
-(void)addAction{
 NSLog(@"add");
 self.name = _tf_name.text;
 self.age = [_tf_age.text integerValue];

 TestBean* bean = [[TestBean alloc]init];
 bean.name = self.name;
 bean.age = self.age;
 RLMRealm *realm = [RLMRealm defaultRealm];
 [realm transactionWithBlock:^{
  [realm addObject:bean];
 }];

}
-(void)deleteAction{

 NSLog(@"delete");
 RLMResults *dogs = [TestBean allObjects];
 RLMRealm *realm = [RLMRealm defaultRealm];
 [realm transactionWithBlock:^{
  for (TestBean *bean in dogs) {
   [realm deleteObject:bean];
  }
 }];
}
-(void)updateAction{
 NSLog(@"update");
 RLMResults *dogs = [TestBean allObjects];
 [[RLMRealm defaultRealm] transactionWithBlock:^{
  for (TestBean *bean in dogs) {
   bean.name = @"李四";
  }
 }];
}
-(void)queryAction{
 NSLog(@"query");
 RLMResults *dogs = [TestBean allObjects];
 [[RLMRealm defaultRealm] transactionWithBlock:^{
  for (TestBean *bean in dogs) {
   NSLog(@"%@",bean.name);
  }
 }];

}
-(void)sortAction{
 NSLog(@"query");
 RLMResults *dogs = [[TestBean allObjects] sortedResultsUsingKeyPath:@"name" ascending:YES];
 [[RLMRealm defaultRealm] transactionWithBlock:^{
  for (TestBean *bean in dogs) {
   NSLog(@"%@",bean.name);
  }
 }];

}
- (void)didReceiveMemoryWarning {
 [super didReceiveMemoryWarning];
 // Dispose of any resources that can be recreated.
}

@end

以上这篇基于iOS Realm数据库的使用实例详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

您可能感兴趣的文章:

  • IOS 数据库升级数据迁移的实例详解
(0)

相关推荐

  • IOS 数据库升级数据迁移的实例详解

    IOS 数据库升级数据迁移的实例详解 概要: 很久以前就遇到过数据库版本升级的引用场景,当时的做法是简单的删除旧的数据库文件,重建数据库和表结构,这种暴力升级的方式会导致旧的数据的丢失,现在看来这并不不是一个优雅的解决方案,现在一个新的项目中又使用到了数据库,我不得不重新考虑这个问题,我希望用一种比较优雅的方式去解决这个问题,以后我们还会遇到类似的场景,我们都想做的更好不是吗? 理想的情况是:数据库升级,表结构.主键和约束有变化,新的表结构建立之后会自动的从旧的表检索数据,相同的字段进行映射迁移

  • 基于iOS Realm数据库的使用实例详解

    首先下载Realm源代码,https://realm.io/cn/docs/objc/latest 将下载的文件解压,从 ios/static/ 目录中将 Realm.framework 拖曳到 Xcode 工程的文件导航器内,然后在 Xcode 文件导航器中选中工程.然后选择应用目标,前往 Build Phases 选项卡.在 Link Binary with Libraries 部分中单击 + 按钮,然后添加 libc++.tbd 和 libz.tbd.这样还没有完,我们还需要安装插件,打开

  • Spring AOP切面解决数据库读写分离实例详解

    Spring AOP切面解决数据库读写分离实例详解 为了减轻数据库的压力,一般会使用数据库主从(master/slave)的方式,但是这种方式会给应用程序带来一定的麻烦,比如说,应用程序如何做到把数据写到master库,而读取数据的时候,从slave库读取.如果应用程序判断失误,把数据写入到slave库,会给系统造成致命的打击. 解决读写分离的方案很多,常用的有SQL解析.动态设置数据源.SQL解析主要是通过分析sql语句是insert/select/update/delete中的哪一种,从而对

  • IOS 获取APP 版本号的实例详解

    IOS 获取APP 版本号的实例详解 看代码的时候看到一句,用于获取.plist文件的版本号 labelVersion.text = [NSString stringWithFormat:@"v%@", [[NSBundle mainBundle] objectForInfoDictionaryKey:(NSString*)kCFBundleVersionKey]]; 比较感兴趣的是后面的参数 kcFBundleVersionKey ,竟然是CFBundle.h已经定于好的属性,下面有

  • IOS UITableView颜色设置的实例详解

    IOS UITableView颜色设置的实例详解 1.系统默认的颜色设置  //无色 cell.selectionStyle = UITableViewCellSelectionStyleNone; //蓝色 cell.selectionStyle = UITableViewCellSelectionStyleBlue; //灰色 cell.selectionStyle = UITableViewCellSelectionStyleGray; 2.自定义颜色和背景设置 改变UITableView

  • IOS 创建并发线程的实例详解

    IOS 创建并发线程的实例详解 创建并发线程 主线程一般都是处理UI界面及用户交互的事儿的.其他的事一般就要另外的线程去处理,如下载,计算等... 现在先简单创建3个线程,分别打印出1-1000,,为了方便,线程3就放在主线程中执行. - (void) firstCounter{ @autoreleasepool { NSUInteger counter = 0; for (counter = 0; counter < 1000; counter++){ NSLog(@"First Cou

  • Hibernate识别数据库特有字段实例详解

    Hibernate识别数据库特有字段实例详解 前言: Hibernate已经为绝大多数常用的数据库数据类型提供了内置支持,但对于某些数据库的专属字段支持就不够好了. 这些特殊数据类型往往提供了比常规数据类型更好的数据表达能力,更符合我们的业务场景.比如PostgreSQL的Interval类型,可以非常方便的保存一个时间段的数据. 本文以添加Interval类型支持为例,说明为Hibernate添加特有数据类型支持的方法. Hibernate提供了丰富的数据类型支持,但对于部分数据库专有的数据类

  • IOS文件的简单读写实例详解

    IOS文件的简单读写实例详解 数组(可变与不可变)和字典(可变与不可变)中元素对象的类型,必须是NSString,NSArray,NSDictionary,NSData,否则不能直接写入文件 #pragma mark---NSString的写入与读取--- //1:获取路径 NSString *docunments = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)firstObje

  • 基于vue+canvas的excel-like组件实例详解

    a vue component,基于vue的表格组件,主要解决大数据量的表格渲染性能问题,使用canvas绘制表格,同时支持类似excel的批量选中,复制黏贴删除,实时编辑等功能. vue-grid-canvas Install NPM / Yarn Install the package: npm install vue-canvas-grid --save Then import it in your project import Vue from 'vue' import Grid fro

  • Python数据库sqlite3图文实例详解

    目录 前言 sqlite3数据库 1.需要的模块(只有一个) 2.模块的使用 2.1创建与数据库的连接 2.2创建游标 2.3创建 table 2.4插入数据 2.5查找数据 快乐的coding时间! 最后 前言 提到数据库,大家第一时间想到的可能是 sql 数据库,这种数据库非常好用,但是对于新手就不是很容易上手,需要熟悉一段时间才可以大概掌握.这种数据库在大型的项目开发过程中用到的地方不会很多,但是一些普通的项目还是很实用的,大大减少了代码量. sqlite3数据库 sqlite3 数据库是

  • 基于ThinkPHP实现的日历功能实例详解

    本文实例讲述了基于ThinkPHP实现的日历功能.分享给大家供大家参考,具体如下: 开发环境介绍 最新,闲来没事,便开发了一款简单的日历,来统计工作情况.为了开发便捷,使用ThinkPHP架构.界面如下图 备注:每页包含上一个月,当前月,下一个月的日期,并用不同的颜色区分,如果某天工作了,便圈出来. 主要是以下两个文件 重要文件描述 功能文件 CalenDar.class.php主要负责,获取日历详细信息的,不涉及用户数据操作. 代码如下: <?php namespace Util; class

随机推荐