版權聲明:本文為部落客原創文章,未經部落客允許不得轉載。 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.支援的類型
- Realm支援以下的屬性類型:Bool、Int8、Int16、Int32、Int64、Double、Float、String、NSDate(精度到秒)以及NSData.
- 也可以使用List 和Object來建立諸如一對多、一對一之類的關系模型,此外Object的子類也支援此功能。
3.Realm的安裝配置
- Realm的官網去下載下傳最新架構: http://static.realm.io/downloads/swift/latest
- 拖拽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)
}
}
代碼位址: