2

我有一个使用 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
4

0 回答 0