ios - 打开sqlite数据库

时间:2012-06-28 20:14:13

标签: ios xcode sqlite

我正在尝试从sqlite数据库中读取数据并将其显示在ios应用程序的表视图中。但由于某种原因,我无法打开sqlite数据库,应用程序崩溃了 - 无法打开数据库。

我使用Firefox sqlite管理器创建了数据库,并将文件复制到Xcode项目中。

这是我的代码 -

-(NSString *)dataFilePath{
    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory , NSUserDomainMask, YES);
    NSString *documentsDir = [paths objectAtIndex:0];
    return [documentsDir stringByAppendingPathComponent:kFilename];
}

我正在尝试使用viewDidLoad中的sqlite3_open_v2命令打开数据库

sqlite3 *database;

    if (sqlite3_open_v2([[self dataFilePath] UTF8String], &database, SQLITE_OPEN_READWRITE, NULL) != SQLITE_OK) {
        sqlite3_close(database); // not sure you need to close if the open failed
        NSAssert(0, @"Failed to open database");
    }

2 个答案:

答案 0 :(得分:13)

这就是我打开数据库的方式。我已经很长时间没有做SQLite了,除了提供我在自己的应用程序中使用的代码之外,我无法给你太多帮助。这是我在我的应用程序中使用的类。

static sqlite3 *database;
static sqlite3_stmt *enableForeignKey;

@implementation DBAdapter

+ (sqlite3 *)sharedInstance {

    if (database == NULL) {
        sqlite3 *newDBconnection;

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

        if (sqlite3_open([path UTF8String], &newDBconnection) == SQLITE_OK) {   
            //NSLog(@"Database Successfully Opened :)");
            database = newDBconnection;

            if (sqlite3_prepare_v2(database, "PRAGMA foreign_keys = ON", -1, &enableForeignKey, NULL) != SQLITE_OK) {
                NSLog(@"ERROR IN PRAGMA!");
            }

            sqlite3_finalize(enableForeignKey);

        } else {
            NSLog(@"Error in opening database :(");
            database = NULL;
        }
    }

    return database;
}

答案 1 :(得分:3)

在我们在ios - sqlite prepare statement的评论中讨论您的问题时,我是否正确?也就是说,我们希望确保数据库包含在捆绑包中(通过在Xcode中确认目标的“构建阶段”中的“复制捆绑资源”设置)并且您希望您的应用程序检查数据库是否存在在您的文档文件夹中,如果它不存在,您将其从捆绑包([[[NSBundle mainBundle] bundlePath] stringByAppendingPathComponent:kFilename])复制到您的文档文件夹。

这可能超出了原始问题的范围,但是当您考虑最终部署应用程序时,更重要的是,您的应用程序的后续升级/发布时,您可能希望将某些表添加到数据库中数据库版本号,可用于确定用户在其文档文件夹中具有的数据库版本,并对您可能需要支持最新版本的应用程序的数据库进行任何修改。只是一个想法。

无论如何,如果您还有任何未解决的问题,请告诉我们。否则我会假设我们已经解决了你的问题。