我有一个使用 Core Data Persistent Store 的 iOS 应用程序。我有几个人在测试应用程序,需要对数据模型进行一些更改,特别是将属性的类型从“NSString”更改为“int16_t”。
这是我到目前为止所做的:
- 创建了一个新的模型版本
- 更改了属性类型
- 添加了一个映射模型(我不确定我在这里需要什么。我有一个带有自定义策略的 EntityMapping)
- 创建了自定义策略(如下所列)
我正在使用 MagicalRecord。正在执行迁移,但似乎正在清除数据库。我能够在本地读取 SQLite 文件并且可以看到表列的更改(但不是每次我清理、加载旧应用程序版本和执行迁移时)。
我怎样才能让这样的事情起作用?我想动态读取字符串并计算正确的值。现在我将它设置为 1 作为 NSNumber。我不确定如何为 int 创建有效的 NSExpression
这是我的自定义政策:
@implementation MessageLabelMigration
- (BOOL)createDestinationInstancesForSourceInstance:(NSManagedObject *)instance
entityMapping:(NSEntityMapping *)mapping
manager:(NSMigrationManager *)manager
error:(NSError **)error {
NSArray *_properties = [mapping attributeMappings];
NSLog(@"_properties: %@", _properties);
for (NSPropertyMapping *_property in _properties) {
if ([[_property name] isEqualToString:@"label"]) {
NSExpression *_expression = [NSExpression expressionForConstantValue:[NSNumber numberWithUnsignedShort:1]];
[_property setValueExpression:_expression];
}
}
return [super createDestinationInstancesForSourceInstance:instance
entityMapping:mapping
manager:manager
error:error];
}
@end