我编写了一个生成谜题的应用程序,我想将其存储在核心数据中 - 或者在任何商店中都是最合适的。我还想搜索以前存储的谜题,以确定生成的谜题是否重复。
每个谜题都由一个50到100位的数组表示,我希望能够存储数千个。
似乎最简单的解决方案是将数组转换为字符串,因为我已经知道如何使用字符串生成Core Data fetch请求。我知道它也可以在Core Data中存储二进制数据,但似乎不能根据这些数据获取实体吗?
我是否缺少哪种选项更适合此类任务?
感谢您的帮助!
答案 0 :(得分:1)
如果在核心数据中使用Transformable数据类型,则可以将NSArray存储在核心数据中。
您可以将这些添加到NSManagedObject子类
+ (Class)transformedValueClass
{
return [NSArray class];
}
+ (BOOL)allowsReverseTransformation
{
return YES;
}
- (id)transformedValue:(id)value
{
return [NSKeyedArchiver archivedDataWithRootObject:value];
}
- (id)reverseTransformedValue:(id)value
{
return [NSKeyedUnarchiver unarchiveObjectWithData:value];
}
以下是此
的教程http://www.lextech.com/2013/01/core-data-transformable-attributes/
如果您决定保存每个拼图,核心数据可以获取不同的对象。
How to fetch distinct values in Core Data?
否则你需要在保存之前进行比较。
祝你好运
答案 1 :(得分:1)
你说你的谜题存储为数字,因此拼图的字符串表示非常合适。
核心数据关系是一个不允许重复的NSSet对象,因此如果您的核心数据关系为puzzles
,则无法添加重复的拼图。但是,Core Data根据objectId
属性定义副本,而不是实体的属性。因此,在用于拼图的NSManagedObject子类中,您将覆盖validateForInsert
和validateForUpdate
方法。在下面的示例中,我假设拼图实体有一个名为stringRepresentation
的属性,用于保存拼图字符串:
- (BOOL)validateForUpdate:(NSError **)error
{
return [self valueIsUnique:self.stringRepresentaion
forKey:@"stringRepresentation"
error:error];
}
- (BOOL)validateForInsert:(NSError **)error
{
return [self valueIsUnique:self.stringRepresentaion
forKey:@"stringRepresentation"
error:error];
}
- (BOOL)valueIsUnique:(NSString *)value
forKey:(NSString *)key
error:(NSError **)error
{
NSString * entityName = [[self entity] name];
NSManagedObjectContext *moc = self.managedObjectContext;
NSEntityDescription *entityDescription = [NSEntityDescription
entityForName:entityName
inManagedObjectContext:moc];
NSFetchRequest *request = [[NSFetchRequest alloc] init];
[request setEntity:entityDescription];
NSPredicate * filter = [NSPredicate predicateWithFormat:@"%K LIKE[c] %@", key, value];
[request setPredicate:filter];
NSArray *array = [moc executeFetchRequest:request error:error];
if (array == nil)
{
NSLog(@"Error retrieving array of values %@", *error);
array = [NSArray array];
}
if (array.count == 1)
{
return YES;
}
if (error != NULL)
{
NSString * propertyName = NSLocalizedString(key, nil);
NSString * errorString = NSLocalizedString(@"%@ must be unique", nil);
errorString = [NSString stringWithFormat:errorString, propertyName];
NSDictionary *userInfoDict = @{ NSLocalizedDescriptionKey : errorString,
NSValidationObjectErrorKey : self,
NSValidationKeyErrorKey : key};
*error = [[NSError alloc] initWithDomain:NSCocoaErrorDomain
code:NSManagedObjectValidationError
userInfo:userInfoDict];
}
return NO;
}