realm数据库使用

realm数据库使用

大家好,又见面了,我是全栈君。

Realm的优点

  1.跨平台:Realm可同时兼顾iOS和Android两个平台,使用时不用考虑内部数据的架构不同。

  2.简单易用:相比Core Data 和 SQLite 晦涩难懂的代码与知识要简单的多,可以减少开发成本

  3.可视化:可以使用Realm Browser ,随时查看数据库中的数据

  4.查询速度极快

Realm支持OC和Swift语言开发。

 

使用CocoaPods进行管理Realm第三方库

platform :ios , ‘8.0’
target ‘项目名称’ do
pod ‘Realm’
end 
 
RLMRealm:Realm是框架的核心所在,该类提供默认的构造方法defaultRealm
RLMRealm *reamlm = [RLMRealm defaultRealm];

RLMObject :创建存储的数据模型时,需要继承这个类

#import <Realm/Realm.h>

@interface ACLModel : RLMObject

@property NSString *systemSn;
@property NSInteger permissionValue;
@property NSString *moduleSn;

@end

写操作事务(Write Transactions):数据库中的所有操作(插入,查询,删除,修改)

查询(Queries):要在数据库中检索信息

 
创建数据库,并设置数据库的名字和存储的地方
– (
void)creatDataBaseWithName:(NSString *)databaseName {
NSArray *docPath = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *path = [docPath objectAtIndex:0];
NSString *filePath = [path stringByAppendingPathComponent:databaseName];
NSLog(@”数据库目录 = %@”,filePath);
RLMRealmConfiguration *config = [RLMRealmConfiguration defaultConfiguration];
config.fileURL = [NSURL URLWithString:filePath];
[RLMRealmConfiguration setDefaultConfiguration:config];
}
 
设置主键需要重写
+ (NSString *)primaryKey { return @"id"; }


单个写入操作将会阻塞其余的操作
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
  RLMRealm *realm = [RLMRealm defaultRealm];
  [realm transactionWithBlock:^{ [
    realm addObject: Car];
    }];
  });
数据的查询

RLMResults *results = [ACLModel objectsWhere:@”systemSn = ‘assets’ AND moduleSn = ‘check’ AND permissionValue = 0″];
NSLog(@”======%lu”,(unsigned long)results.count);





转载于:https://www.cnblogs.com/lcl15/p/8288094.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107755.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 数据恢复案例之Linux服务器数据恢复成功案例

    数据恢复案例之Linux服务器数据恢复成功案例一、服务器数据恢复故障描述介绍数据恢复案例前照例先介绍故障服务器的物理状况。本次数据恢复的服务器是linux操作系统,某品牌730系列服务器,MD3200系列存储。导致数据丢失的原因是机房意外断电导致系统无法正常启动,客户管理员对无法访问的服务器进行了修复操作后进入系统查看数据,服务器部分文件已经丢失。于是客户管理员联系了数据恢复中心进行服务器数据恢复。二、服务器数据恢复故障分析1.备…

    2022年5月9日
    56
  • JSONArray与JSONObject

    JSONArray与JSONObject1,JSONObject json对象,就是一个键对应一个值,使用的是大括号{},如:{key:value}2,JSONArray json数组,使用中括号[],只不过数组里面的项也是json键值对格式的 Json对象中添加的是键值对,JSONArray中添加的是Json对象JSONObject Json = new JSONObject();  JSONArray JsonArray =…

    2022年5月20日
    111
  • MyBatis模糊查询的4种实现方式

    MyBatis模糊查询的4种实现方式1、根据姓名模糊查询员工信息1.1、方式一步骤一:编写配置文件步骤二:测试步骤三:分析此种方式需要在调用处手动的去添加“%”通配符。1.2、方式二说明:使用方式一可以实现模糊查询,但是有一点不方便的地方就是:在测试类中,调用selectList()方法传参时需要调用者手动的添加%号通配符,显然是麻烦的,能否在映射配置文件中直接将%号写好呢?有的朋友可能会这么想,好办,直接在配置文件中这么写:形如1:测试后发现,程序会报错,原因是:缺少单引号。这…

    2025年7月7日
    4
  • Ext中apply及applyIf方法的应用

    Ext中apply及applyIf方法的应用Ext中apply及applyIf方法的应用        apply及applyIf方法都是用于实现把一个对象中的属性应用于另外一个对象中,相当于属性拷贝。不同的是apply将会覆盖目标对象中的属性,而applyIf只拷贝目标对象中没有而源对象中有的属性。apply方法的签名为“apply(Objectobj,Objectconfig,Ob

    2022年7月28日
    6
  • linux ettercap,CentOS下安装ettercap

    linux ettercap,CentOS下安装ettercapCentOS下安装ettercapettercap下载地址http://ettercap.sourceforge.net/download.php下载好之后解压出来,进入到解压目录#tarzxvfettercap-NG-0.7.3.tar.gz#cdettercap-NG-0.7.3阅读README#vimREADMEMANDATORY://安装必须依赖的libpcap>=…

    2022年6月28日
    42
  • AFL 源码分析

    AFL 源码分析AFL 作为 C C 白盒 fuzzer 的鼻祖 为后来许多优秀的 fuzzer 提供了技术支持 衍生了很多 fuzzer 工具 本文只是站在巨人的肩膀上 参考了大量的博客 重新审计了部分源码 很多细节并没有深究 但对理解 AFL 的思想还是有一定作用的

    2025年11月14日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号