Swift学习第十二枪----移动数据库王者Realm入门教程

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u010046908/article/details/51636392 今天给大家带来的是堪称是一个可以替代SQLite,Core Data 的以及ORMlibraries的轻量级数据库—Realm移动端数据库。
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u010046908/article/details/51636392

今天给大家带来的是堪称是一个可以替代SQLite,Core Data 的以及ORMlibraries的轻量级数据库—Realm移动端数据库。

相比SQLite,Realm更快并且具有很多现代数据库的特性,比如支持JSON,流式api,数据变更通知,以及加密支持,这些都为IOS开发者带来了方便。

Ream提供了五种编程方式的实现。分别是Java,Objective C,Swift,React-Native,tamarin。在前面我着重介绍在Android中的使用。现在来介绍在Swift中得使用。

1 .关于Realm的几个特点:

(1)使用简单,大部分常用的功能(比如插入、查询等)都可以用一行简单的代码轻松完成,学习成本低。
(2)Realm不是基于Core Data,也不是基于SQLite封装构建的。它有自己的数据库存储引擎。
(3)Realm具有良好的跨平台特性,可以在iOS和Android平台上共同使用。代码可以使用 Swift 、 Objective-C 以及 Java 语言来编写。
(4)Realm 还提供了一个轻量级的数据库查看工具(Realm Browser)。你也可以用它进行一些简单的编辑操作(比如插入和删除操作)

2.支持的类型

  1. Realm支持以下的属性类型:Bool、Int8、Int16、Int32、Int64、Double、Float、String、NSDate(精度到秒)以及NSData.
  2. 也可以使用List 和Object来建立诸如一对多、一对一之类的关系模型,此外Object的子类也支持此功能。

3.Realm的安装配置

  1. Realm的官网去下载最新框架:http://static.realm.io/downloads/swift/latest
  2. 拖拽RealmSwift.framework和Realm.framework文件到”Embedded Binaries”选项中。选中Copy items if needed并点击Finish
    这里写图片描述

4.开始获取Realm

//
//  RealmUtil.swift
//  HelloSwfit
//
//  Created by lidong on 16/6/11.
//  Copyright © 2016年 lidong. All rights reserved.
//

import Foundation
import RealmSwift
/// RealmUtil工具类
class RealmUtil {


    private static let instance = RealmUtil()
    // 单例  全局的数据访问接口
    class var sharedInstance: RealmUtil
    {

        struct Static {
            static var onceToken : dispatch_once_t = 0
            static var instance : RealmUtil? = nil

        }

        dispatch_once(&Static.onceToken) {
            Static.instance = RealmUtil()
        }
        return Static.instance!
    }


    /**
     得到Realm

     - returns: <#return value description#>
     */
    func getRealm() -> Realm{

        var config = Realm.Configuration()

        // Use the default directory, but replace the filename with the username
        config.fileURL = config.fileURL!.URLByDeletingLastPathComponent?
            .URLByAppendingPathComponent("realm_demo.realm")

        // 创建一个有配置的realm
        let realm = try! Realm(configuration: config)

        return realm

    }
}

5.创建RealmSwift.Object

//
//  Dog.swift
//  HelloSwfit
//
//  Created by lidong on 16/6/11.
//  Copyright © 2016年 lidong. All rights reserved.
//

import UIKit

import RealmSwift

class Dog: Object {
    dynamic var name = ""
    dynamic var age = 0
}

class Person: Object {
    dynamic var name = ""
    dynamic var picture: NSData? = nil // optionals supported
    var dogs = List<Dog>()
}

6.开始对数据库进行简单的增删改查的操作

//
//  HandleData.swift
//  HelloSwfit
//
//  Created by lidong on 16/6/11.
//  Copyright © 2016年 lidong. All rights reserved.
//

import Foundation
import RealmSwift
/// 处理数据
class HandleData {

    /**
     添加一个狗

     - parameter dog: <#dog description#>
     */
    func addDog(dog:Dog){
        let  realm = RealmUtil.sharedInstance.getRealm()

        try! realm.write {
            realm.add(dog)
        }
    }


    /**
     修改一个狗的信息
     - parameter dog: <#dog description#>
     */
    func updateDog(dog:Dog){
        let  realm = RealmUtil.sharedInstance.getRealm()
        try! realm.write {
            realm.add(dog,update:true)
        }
    }



    /**
     删除一个狗的信息
     - parameter dog: <#dog description#>
     */
    func deleteDog(dog:Dog){
        let  realm = RealmUtil.sharedInstance.getRealm()
        try! realm.write {
            realm.delete(dog)
        }
    }
    /**
     查询所有狗的信息

     - returns: <#return value description#>
     */
    func findAll(code:String)  -> RealmSwift.Results<Dog> {

    let  realm = RealmUtil.sharedInstance.getRealm()

    let results = realm.objects(Dog.self).filter("age = \(code)")

    return  results
    }


    /**
     添加一个人

     - parameter p:
     */
    func addPerson(p:Person){
        let  realm = RealmUtil.sharedInstance.getRealm()

        try! realm.write {
            realm.add(p)
        }
    }

    /**
     查找所有的用户信息

     - returns: <#return value description#>
     */
    func findAll() ->   RealmSwift.Results<Person>{


        let  realm = RealmUtil.sharedInstance.getRealm()

        let results = realm.objects(Person.self)

        return  results


    }


}

7.在RealmViewController中简单调用

//
//  RealmDemo.swift
//  HelloSwfit
//
//  Created by lidong on 16/6/11.
//  Copyright © 2016年 lidong. All rights reserved.
//

import UIKit
import RealmSwift
class RealmDemo:UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.backgroundColor = UIColor.whiteColor()
       let h =  HandleData()
//        let dog = Dog()
//        dog.age = 2
//        dog.name = "gggg"
//        h.addDog(dog)
//        let dogs1 = List<Dog>()
//        dogs1.append(dog)
//        
//        let person = Person()
//        person.name = "lidong"
//        person.dogs = dogs1
//        
//        h.addPerson(person)

      let result =   h.findAll()
        print(result)
    }

}

代码地址:

数据中得数据

相关文章
|
2月前
|
SQL 关系型数据库 MySQL
「Go开源」goose:深入学习数据库版本管理工具
「Go开源」goose:深入学习数据库版本管理工具
「Go开源」goose:深入学习数据库版本管理工具
|
2月前
|
SQL 存储 关系型数据库
如何系统地学习数据库?
如何系统地学习数据库?【8月更文挑战第25天】
36 0
|
2月前
|
存储 算法 数据库
带你学习DM数据库的基本操作
带你学习DM数据库的基本操作
160 0
|
3月前
|
SQL 存储 关系型数据库
关系型数据库PostgreSQL学习
【7月更文挑战第4天】
445 2
|
3月前
|
SQL 存储 关系型数据库
关系型数据库SQL Server学习
【7月更文挑战第4天】
52 2
|
3月前
|
存储 SQL 关系型数据库
MySQL数据库学习指南与学习资源推荐
MySQL数据库学习指南与学习资源推荐
|
3月前
|
SQL 存储 Java
SQL数据库学习指南:从基础到高级
SQL数据库学习指南:从基础到高级
|
20天前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
22天前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
168 11
|
17天前
|
存储 SQL 关系型数据库
MySQL的安装&数据库的简单操作
本文介绍了数据库的基本概念及MySQL的安装配置。首先解释了数据库、数据库管理系统和SQL的概念,接着详细描述了MySQL的安装步骤及其全局配置文件my.ini的调整方法。文章还介绍了如何启动MySQL服务,包括配置环境变量和使用命令行的方法。最后,详细说明了数据库的各种操作,如创建、选择和删除数据库的SQL语句,并提供了实际操作示例。
59 13
MySQL的安装&数据库的简单操作
下一篇
无影云桌面