新项目用到了数据库,本来之前用的都是 SQL,但是语法写的实在是恶心,所以使用 Realm 尝试一下。

1、我使用的 pod 库,所以先 pod 库安装一下,安装完别忘了先编译一下,不然 import 不到头文件

platform :ios, '8.0'

target 'realmExmple' do
use_frameworks! pod 'RealmSwift' end

2、在 AppDelegate 的 didFinishLaunchingWithOptions 中添加如下方法,引入头文件 import RealmSwift

        /* Realm 数据库配置,用于数据库的迭代更新 */
let schemaVersion: UInt64 =
// 数据库工具类的版本号
SSRealmTool.schemaVersion = schemaVersion let config = Realm.Configuration(schemaVersion: schemaVersion, migrationBlock: { (migration, oldSchemaVersion) in
/* 什么都不要做!Realm 会自行检测新增和需要移除的属性,然后自动更新硬盘上的数据库架构 */
if (oldSchemaVersion < schemaVersion) {
print("----数据库升级")
}
}) Realm.Configuration.defaultConfiguration = config Realm.asyncOpen { (realm, error) in
/* Realm 成功打开,迁移已在后台线程中完成 */
if let _ = realm { print("Realm 数据库配置成功")
} else if let error = error { /* 处理打开 Realm 时所发生的错误 */ print("Realm 数据库配置失败:\(error.localizedDescription)")
}
}

3、接下来开始写数据库工具类,新建一个 Swift 文件 SSRealmTool

class SSRealmTool {

    /// 数据库版本号
static var schemaVersion: UInt64 = /// 唯一的数据库操作的 Realm
static let ss_realm = realm() /// 获取数据库操作的 Realm
private static func realm() -> Realm { // 获取数据库文件路径
let fileURL = URL(string: NSHomeDirectory() + "/Documents/demo.realm")
// 在 APPdelegate 中需要配置版本号时,这里也需要配置版本号
let config = Realm.Configuration(fileURL: fileURL, schemaVersion: schemaVersion) return try! Realm(configuration: config)
} }

4、新建两个对象 SSDog SSPerson

class SSDog: Object {
// 主键不自增,如果要主键的话,这样写不会有重复的主键
// @objc dynamic var id = NSUUID().UUIDString
// @objc dynamic **必须写
@objc dynamic var name = ""
@objc dynamic var age =
@objc dynamic var date = Date()
// 如果需要增加属性的话,只需要在 appdelegate 的版本号加 1 即可自动升级
// @objc dynamic var weight = 1 /// 所属人可选
@objc dynamic var person: SSPerson? // 设置主键的方法
// override static func primaryKey() -> String? {
// return "id"
// }
}
class SSPerson: Object {

    @objc dynamic var name = ""
@objc dynamic var age = // 数组使用 List
let dogs = List<SSDog>()
}

5、可以在 viewController 中调用我们的数据库了

5.1、添加一个 person

        let realm = SSRealmTool.ss_realm

        let person = SSPerson()
person.name = "person\(arc4random_uniform(1000))"
person.age = Int(arc4random_uniform()) for _ in ..< { let dog = SSDog()
dog.name = "dog\(arc4random_uniform(1000))"
dog.age = Int(arc4random_uniform())
dog.person = person
person.dogs.append(dog)
print("添加一只狗:\(dog.name),age:\(dog.age),date:\(dog.date)")
} try! realm.write {
realm.add(person)
print("添加一个人:\(person.name),年龄:\(person.age)")
}

5.2、查询

        let realm = SSRealmTool.ss_realm
print("总共有\(realm.objects(SSPerson.self).count)位人")
print("总共有\(realm.objects(SSDog.self).count)只狗") if realm.objects(SSDog.self).count == || realm.objects(SSPerson.self).count == {
return
}
let dogs = realm.objects(SSDog.self).filter("age <= 5") for dog in dogs {
print("---查询狗:\(dog.name), age:\(dog.age),主人是:\(dog.person?.name ?? "无人")")
} print("---------person---------") let persons = realm.objects(SSPerson.self).filter("age <= 10") for person in persons {
print("---查询name:\(person.name), 有\(person.dogs.count)只狗")
print("-----每个人下面的狗-------")
let someDogs = person.dogs.filter("age <= 5")
for someDog in someDogs {
print("---查询狗:\(someDog.name), age:\(someDog.age),主人是:\(someDog.person?.name ?? "无人")")
}
}

5.3、更新

        let realm = SSRealmTool.ss_realm

        let dogs = realm.objects(SSDog.self).filter("age > 5")

        for dog in dogs {

            try! realm.write {

                print("---更新前name:\(dog.name), age:\(dog.age)")
dog.name += "修改"
// realm.add(dog, update: true) // 这需要主键
}
} let dogs2 = realm.objects(SSDog.self).filter("age > 5") for dog in dogs2 {
print("---更新后name:\(dog.name), age:\(dog.age)")
}

5.4、删除

        let realm = SSRealmTool.ss_realm

        let person = SSPerson()
person.name = "person\(arc4random_uniform(1000))"
person.age = Int(arc4random_uniform()) for _ in ..< { let dog = SSDog()
dog.name = "dog\(arc4random_uniform(1000))"
dog.age = Int(arc4random_uniform())
dog.person = person
person.dogs.append(dog)
print("添加一只狗:\(dog.name),age:\(dog.age),date:\(dog.date)")
} try! realm.write {
realm.add(person)
print("添加一个人:\(person.name),年龄:\(person.age)")
}

Swift Realm 完整使用记录的更多相关文章

  1. [IOS]Swift使用SVGKit的记录

    最近打算使用swift和SVGkit做一个app,遇到了好多状况,对于初学者的几个概念,一个是静态库,第二个是oc和swift混编,第三个是xcode6b4的类库不齐全. 首先是SVGKit的GitH ...

  2. Centos下分布式跟踪工具Pinpoint的完整部署记录

    一.Pinpoint简单介绍Pinpoint是一款对Java编写的大规模分布式系统的APM工具,有些人也喜欢称呼这类工具为调用链系统.分布式跟踪系统.一般来说,前端向后台发起一个查询请求,后台服务可能 ...

  3. kubeadm安装kubernetes 1.13.1集群完整部署记录

    k8s是什么 Kubernetes简称为k8s,它是 Google 开源的容器集群管理系统.在 Docker 技术的基础上,为容器化的应用提供部署运行.资源调度.服务发现和动态伸缩等一系列完整功能,提 ...

  4. [Swift]LeetCode552. 学生出勤记录 II | Student Attendance Record II

    Given a positive integer n, return the number of all possible attendance records with length n, whic ...

  5. ProxySQL+MGR实现读写分离和主节点故障无感知切换 - 完整操作记录

    前面的文章介绍了ProxySQL用法,这里说下ProxySQL中间件针对Mysql组复制模式实现读写分离以及主节点故障时能够自动切换到新的主节点,而应用对此过程无感知的功能.Mysql组复制(MGR) ...

  6. Tomcat通过Redis实现session共享的完整部署记录

    对于生产环境有了一定规模的tomcat集群业务来说,要实现session会话共享,比较稳妥的方式就是使用数据库持久化session.为什么要持久化session(共享session)呢?因为在客户端每 ...

  7. Ubuntu16.04下安装QQ的完整操作记录(经验证可用)

    本机安装了Ubuntu16.04系统,用于日常运维办公.打算在Ubuntu上安装QQ,如下操作记录也使用于Ubuntu18.04: 1)先下载特制的QQ程序包(其实就是基于Wine容器做了一些封装,程 ...

  8. Tomcat通过Memcached实现session共享的完整部署记录

    对于web应用集群的技术实现而言,最大的难点就是:如何能在集群中的多个节点之间保持数据的一致性,会话(Session)信息是这些数据中最重要的一块.要实现这一点, 大体上有两种方式:一种是把所有Ses ...

  9. Centos7.2下OpenVPN 环境完整部署记录

    关于OpenVPN的有关介绍及为何使用OpenVPN在此就不做赘述了,下面直接记录Centos7.2系统下部署OpenVPN环境的操作过程: 1) 先将本机的yum换成阿里云的yum源 [root@t ...

随机推荐

  1. MemCache在网站中的使用

    MemCache安装好后,网站一直没法使用,后来查找资料,发现需要在配置文件里写几行代码,如下所示 <enyim.com> <memcached protocol="Tex ...

  2. 在MyEclipse使用Git新建分支,并上传分支---图文教程

    1.选中项目,右键--->Team--->Switch To--->New Branch: 2.在弹出的窗口中,填写新建的分支名称,如下图 3.当前分支就会变成新建分支“test” ...

  3. [STM32F103]PWM输入捕获配置

    l 初始化定时器和通道对应IO的时钟. l 初始化IO口,模式为输入: GPIO_Init(); GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD; //PA0 ...

  4. ntp服务

    ntp服务主要是用于对计算机的时间同步管理操作.时间是对服务器来说是很重要的,一般很多网站都需要读取服务器时间来记录相关信息,如果时间不准,则可能造成很大的影响,对于集群,也需要时间同步. 部署安装N ...

  5. VS2017无法进入安装界面问题的解决方法

    VS2017无法进入安装界面问题的解决方法 打开C:\Program Files (x86)\Microsoft Visual Studio\Installer\vs_installer.exe也没有 ...

  6. kolla queens on centos7.5 -all in one

    目录 环境准备 开始配置 快照,快照,快照 pull镜像并部署 登录配置OpenStack 环境准备 我这里用workstation创建了一个虚拟机,安装centos7.5 mini系统,这台虚拟机上 ...

  7. flink入门:01 构建简单运行程序

    1. mac平台安装flink(默认最新版) brew install apache-flink 安装结果: Version 1.7.1, commit ID: 89eafb4 2. jdk版本,我尝 ...

  8. 未能加载文件或程序集“Microsoft.Vbe.Interop, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c”或它的某一个依赖项。系统找不到制定的文件。

    未能加载文件或程序集"Microsoft.Vbe.Interop, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e ...

  9. 【JsonView工具】谷歌浏览器中安装JsonView扩展程序

    接口测试过程中,有时候要查看接口返回的数据(比如Get接口),为了更方便的查看,发现这个插件挺好用的. 实际开发工作中经常用到json数据,那么就会有这样一个需求:在谷歌浏览器中访问URL地址返回的j ...

  10. scrpy-cookie

    两种方法模拟登陆 1.直接携带cookie import re import scrapy class RenrenSpider(scrapy.Spider): name = 'renren' all ...