ObjectiveRecord alternatives and similar libraries
Based on the "Core Data" category.
Alternatively, view ObjectiveRecord alternatives based on common mentions on social networks and blogs.
-
PrediKit
An NSPredicate DSL for iOS, OSX, tvOS, & watchOS. Inspired by SnapKit and lovingly written in Swift. -
Skopelos
A minimalistic, thread safe, non-boilerplate and super easy to use version of Active Record on Core Data. Simply all you need for doing Core Data. Swift flavour. -
JustPersist
DISCONTINUED. JustPersist is the easiest and safest way to do persistence on iOS with Core Data support out of the box. It also allows you to migrate to any other persistence framework with minimal effort. -
SLRESTfulCoreData
Objc naming conventions, autogenerated accessors at runtime, URL substitutions and intelligent attribute mapping -
CloudCore
Robust CoreData-CloudKit synchronization, including offline queuing, relationships, private, shared and public databases, field-level deltas, encrypted values, maskable attributes, cacheable assets, and more. -
Cadmium
A Swift framework that wraps CoreData, hides context complexity, and helps facilitate best practices. -
CoreDataDandy
DISCONTINUED. A feature-light wrapper around Core Data that simplifies common database operations.
SaaSHub - Software Alternatives and Reviews
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of ObjectiveRecord or a related project?
README
ObjectiveRecord
Objective Record is a lightweight ActiveRecord way of managing Core Data objects. If you've used Ruby on Rails before, it might sound familiar.
No AppDelegate code required. It's fully tested with Kiwi.
Usage
- Install with CocoaPods or clone
#import "ObjectiveRecord.h"
in your model or .pch file.
Create / Save / Delete
Person *john = [Person create];
john.name = @"John";
[john save];
[john delete];
[Person create:@{
@"name" : @"John",
@"age" : @12,
@"member" : @NO
}];
Finders
// all Person entities from the database
NSArray *people = [Person all];
// Person entities with name John
NSArray *johns = [Person where:@"name == 'John'"];
// And of course, John Doe!
Person *johnDoe = [Person find:@"name == %@ AND surname == %@", @"John", @"Doe"];
// Members over 18 from NY
NSArray *people = [Person where:@{
@"age" : @18,
@"member" : @YES,
@"state" : @"NY"
}];
// You can even write your own NSPredicate
NSPredicate *predicate = [NSPredicate
predicateWithFormat:@"(name like[cd] %@) AND (birthday > %@)",
name, birthday];
NSArray *results = [Person where:predicate];
Order and Limit
// People by their last name ascending
NSArray *sortedPeople = [Person allWithOrder:@"surname"];
// People named John by their last name Z to A
NSArray *reversedPeople = [Person where:@{@"name" : @"John"}
order:@{@"surname" : @"DESC"}];
// You can use NSSortDescriptor too
NSArray *people = [Person allWithOrder:[NSSortDescriptor sortDescriptorWithKey:@"name" ascending:YES]];
// And multiple orderings with any of the above
NSArray *morePeople = [Person allWithOrder:@"surname ASC, name DESC"];
// Just the first 5 people named John sorted by last name
NSArray *fivePeople = [Person where:@"name == 'John'"
order:@{@"surname" : @"ASC"}
limit:@(5)];
Aggregation
// count all Person entities
NSUInteger personCount = [Person count];
// count people named John
NSUInteger johnCount = [Person countWhere:@"name == 'John'"];
Custom ManagedObjectContext
NSManagedObjectContext *newContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSPrivateQueueConcurrencyType];
newContext.persistentStoreCoordinator = [[CoreDataManager instance] persistentStoreCoordinator];
Person *john = [Person createInContext:newContext];
Person *john = [Person find:@"name == 'John'" inContext:newContext];
NSArray *people = [Person allInContext:newContext];
Custom CoreData model or .sqlite database
If you've added the Core Data manually, you can change the custom model and database name on CoreDataManager
[CoreDataManager sharedManager].modelName = @"MyModelName";
[CoreDataManager sharedManager].databaseName = @"custom_database_name";
Examples
// find
[[Person all] each:^(Person *person) {
person.member = @NO;
}];
for(Person *person in [Person all]) {
person.member = @YES;
}
// create / save
Person *john = [Person create];
john.name = @"John";
john.surname = @"Wayne";
[john save];
// find / delete
[[Person where: @{ @"member" : @NO }] each:^(Person *person) {
[person delete];
}];
Mapping
The most of the time, your JSON web service returns keys like first_name
, last_name
, etc.
Your ObjC implementation has camelCased properties - firstName
, lastName
.
Since v1.2, camel case is supported automatically - you don't have to do anything! Otherwise, if you have more complex mapping, here's how you do it:
// just override +mappings in your NSManagedObject subclass
// this method is called just once, so you don't have to do any caching / singletons
@implementation Person
+ (NSDictionary *)mappings {
return @{
@"id": @"remoteID",
@"mmbr": @"isMember",
// you can also map relationships, and initialize your graph from a single line
@"employees": @{
@"class": [Person class]
},
@"cars": @{
@"key": @"vehicles",
@"class": [Vehicle class]
}
};
// first_name => firstName is automatically handled
}
@end
Testing
ObjectiveRecord supports CoreData's in-memory store. In any place, before your tests start running, it's enough to call
[[CoreDataManager sharedManager] useInMemoryStore];
Roadmap
- NSIncrementalStore support
License
ObjectiveRecord is available under the MIT license. See the LICENSE file for more information.
*Note that all licence references and agreements mentioned in the ObjectiveRecord README section above
are relevant to that project's source code only.