我有一个以前创建的Sqlite数据库文件,我正在捆绑iOS应用程序。我的问题是将这些数据写入手机的最佳方法是什么,以便我可以从那里的应用程序中更改表格?
我的研究表明,我可能需要循环遍历整个.sql文件,并手动在手机上插入/创建必要的表格和值。
有没有办法只将数据库写入内部存储,然后从那时起操作它?
答案 0 :(得分:3)
您可以将其添加到项目中的支持文件中,然后将该文件作为模板db复制(如果该文件不存在),然后将其打开。一旦你打开它,你就可以用它做你想做的事。
以下是我所做的示例项目中的一些示例代码。在我的示例中,它是一个联系人数据库。请注意,如果不存在,ensurePrepared将如何从捆绑中复制它。我复制到库路径,但您可以复制到文档路径。
- (BOOL)ensureDatabaseOpen: (NSError **)error
{
// already created db connection
if (_contactDb != nil)
{
return YES;
}
NSLog(@">> ContactManager::ensureDatabaseOpen");
if (![self ensureDatabasePrepared:error])
{
return NO;
}
const char *dbpath = [_dbPath UTF8String];
if (sqlite3_open(dbpath, &_contactDb) != SQLITE_OK &&
error != nil)
{
*error = [[[NSError alloc] initWithDomain:@"ContactsManager" code:1000 userInfo:nil] autorelease];
return NO;
}
NSLog(@"opened");
return YES;
}
- (BOOL)ensureDatabasePrepared: (NSError **)error
{
// already prepared
if ((_dbPath != nil) &&
([[NSFileManager defaultManager] fileExistsAtPath:_dbPath]))
{
return YES;
}
// db in main bundle - cant edit. copy to library if !exist
NSString *dbTemplatePath = [[NSBundle mainBundle] pathForResource:@"contacts" ofType:@"db"];
NSLog(@"%@", dbTemplatePath);
NSString *libraryPath = [NSSearchPathForDirectoriesInDomains(NSLibraryDirectory, NSUserDomainMask, YES) lastObject];
_dbPath = [libraryPath stringByAppendingPathComponent:@"contacts.db"];
NSLog(@"dbPath: %@", _dbPath);
// copy db from template to library
if (![[NSFileManager defaultManager] fileExistsAtPath:_dbPath])
{
NSLog(@"db not exists");
NSError *error = nil;
if (![[NSFileManager defaultManager] copyItemAtPath:dbTemplatePath toPath:_dbPath error:&error])
{
return NO;
}
NSLog(@"copied");
}
return YES;
}
答案 1 :(得分:2)
将数据库存储在捆绑包中(在项目中)。在App Delegate中将数据库复制到Documents目录(只有在文档目录中不存在数据库文件时才执行此操作,否则您将始终覆盖您的文件)。在您的代码中,始终引用Document目录中的副本 另请阅读this SO Question以获取有关如何进行复制的一些代码。
瞧。
答案 2 :(得分:2)
将.sql文件包含在项目的资源文件夹中,并在首次启动应用程序时将其复制到用户的文档文件夹中(或者如果找不到该文件)。您可以使用NSFileManager。
查看Where would you place your SQLite database file in an iPhone app?