3

我正在我的应用程序中编写一个重置函数,它将使用一些预先填充的数据将我的 sqlite 数据库恢复到其原始状态。下面的代码从文档目录中删除数据库并从捆绑包中复制数据库,但数据仍然出现在旧数据库中?

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

 if([[NSFileManager defaultManager] fileExistsAtPath:filePath]){ 

    [[NSFileManager defaultManager]      removeItemAtPath:filePath error:nil]; 

}

BOOL success; 
NSFileManager *fileManager = [NSFileManager defaultManager]; NSError *error;

NSString *writableDBPath = [documentsDirectory stringByAppendingPathComponent:@"MoneyMonthly.sqlite"]; 
 NSString *defaultDBPath = [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:@"MoneyMonthly.sqlite"]; 

 success = [fileManager copyItemAtPath:defaultDBPath toPath:writableDBPath error:&error]; 

if (!success) {

    NSAssert1(0, @"Failed to create writable   database file with message '%@'.", [error localizedDescription]); 
}
4

2 回答 2

2

只需关闭现有的 sqlite 数据库,然后再次从包中复制它,覆盖现有的数据库。它的完成方式与第一次复制时的方式基本相同。

于 2012-11-11T21:46:40.697 回答
2

我在我的一个应用程序中执行此操作。我在我的应用程序包中保留了一个预构建的数据库文件。该数据库包含所有表格和示例数据。

当我需要重置用户的数据库时,我将其关闭,然后用捆绑包中的干净副本覆盖数据库。

于 2012-11-11T21:47:49.830 回答