0

我的项目中有一个预定义和预加载的数据库,名为Database,我将其定义如下:AppDelegate

- (NSPersistentStoreCoordinator *)persistentStoreCoordinator {

if (__persistentStoreCoordinator != nil) {
    return __persistentStoreCoordinator;
}



NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *writableDBPath = [documentsDirectory stringByAppendingPathComponent:@"Database.sqlite"];



NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"Database.sqlite"]; //este es el que sirve!!! CREE ESTE

//  NSLog(@"store URL %@", storeURL);

// Put down default db if it doesn't already exist
NSFileManager *fileManager = [NSFileManager defaultManager];
if (![fileManager fileExistsAtPath:writableDBPath]) {
    NSString *defaultStorePath = [[NSBundle mainBundle] pathForResource:@"Database" ofType:@"sqlite"];


    if (defaultStorePath) {
        [fileManager copyItemAtPath:defaultStorePath toPath:writableDBPath error:NULL];
    }
}    

NSError *error = nil;
__persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];
if (![__persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:nil error:&error]) {

    NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
    abort();
}    

return __persistentStoreCoordinator;
}

在任何课程中,我都想从我使用的数据库中调用数据:

-(NSArray *)sqlCall {


AppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];
NSManagedObjectContext *context = [appDelegate managedObjectContext];
NSEntityDescription *entityDesc = [NSEntityDescription entityForName:@"MotherWeekly" inManagedObjectContext:context];
NSFetchRequest *request = [[ NSFetchRequest alloc] init];
[request setFetchLimit:1];
[request setEntity:entityDesc];
NSString *a =[NSString stringWithFormat:@"%@==%d",@"id",pageNumber];
NSPredicate *pred = [NSPredicate predicateWithFormat:a];
[request setPredicate:pred];

NSError *error;
NSArray *objects = [context executeFetchRequest:request
                                          error:&error];

[request release];
return objects ;
}

问题是:当我更新预加载数据库中的一个字段并在我的模拟器或 iPhone 上运行它时,数据似乎是旧的而不是更新的。

PS:在我注意到这个问题之前,我已经将我的应用程序提交到了 AppStore,所以我会拒绝我的二进制文件并使用工作/更新的数据库上传一个新版本,所以请帮助我

提前致谢

4

1 回答 1

1

显然,当您有新的更新商店时,商店不会被删除。因此,您会看到旧值。

如果您想在有新商店的情况下删除商店,您可以检查是否NSUserDefault有版本或告诉您是否需要更新的内容。如果是,请删除持久存储,复制新的并将用户默认设置为新版本。

但是,所有用户数据都会丢失。有两种解决方案:

1)您可以有两个持久存储,一个用于“静态”数据,一个用于用户数据。但是,这可能有点太复杂了。

2) 或者,您可以包含更改数据的信息并简单地更新数据库(仅在数据库不存在时复制,即如果是新安装)。这也将保留用户数据。事实上,如果需要更新的数据不多,再次复制整个数据库似乎没有任何意义。

实际上,如果要复制的数据库的记录少于 10.000 条,那么复制核心数据持久存储可能会有问题。您可以在启动时进行快速后台插入,而不是从任何类型的文件中读取。

于 2013-07-15T18:53:16.333 回答