Go to file
Ivan Vavilov 1fb6cb51fa Update podspec 2017-07-27 17:53:11 +03:00
DAO/Classes Fix persist collection of realm entries, add more robust test 2017-07-27 11:16:38 +03:00
Example Fix persist collection of realm entries, add more robust test 2017-07-27 11:16:38 +03:00
.gitignore Initial commit 2017-06-13 14:06:20 +03:00
DAO.podspec Update podspec 2017-07-27 17:53:11 +03:00
LICENSE Initial commit 2017-06-13 14:06:20 +03:00
README.md Update pic 2017-07-27 12:50:54 +03:00
_Pods.xcodeproj Initial commit 2017-06-13 14:06:20 +03:00

README.md

Issues count Cocoapod Swift License

DAO

An implementation of DAO pattern for CoreData and Realm. Helps you think less about database in your application.

Features

  • Use your persistence layer synchronously for CRUD operations.
  • Abstraction of database objects (entries) from application objects (entities).
  • Abstraction from concurrency.

Install

Cocoapods

For using with CoreData:

pod 'DAO/CoreData'

Or with Realm:

pod 'DAO/Realm'

Usage

// Create DAO instance
let dao = RealmDAO(RLMMessageTranslator())

//...

// Create message entity
let message = Message(entityId: "abc", text: "text")

// Save message to database
try? dao.persist(message)

// Read saved message from database
let savedMessage = dao.read(message.entityId)

// Delete message from database
try? dao.erase(message.entityId)

Please look at the example project for more information.

  • If you have big and complex database schema. Many entities, many relationships.
  • If you want to use many features of database. Realm Mobile Platform, for instance is not compatible with this implementation.
  • If you have thousands of objects (> 10-20K). Performance can be the issue.

Requirements

  • XCode 8
  • Swift 3
  • iOS 9

Authors

Ivan Vavilov - iv@redmadrobot.com