2

我从 sqlite3 数据库读取时遇到了一些问题。

-(void) readMessengesFromDatabase {
    sqlite3 *database;

    messenges = [[NSMutableArray alloc] init];

    if(sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK) {
        NSLog(@"Connection OK");
        const char *sqlStatement = "select * from MessagesData";
        sqlite3_stmt *compiledStatement;
        if(sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK) NSLog(@"connect to table OK");    else NSLog(@"connect to table FALSE");
        if(sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK) { //не проходит условие
            NSLog(@"Connection to table OK");
            while(sqlite3_step(compiledStatement) == SQLITE_ROW) {
                NSLog(@"Read rows OK");
                NSString *dbMessageID = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 0)];
                NSString *dbMessageText = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 1)];
                NSString *dbMessageDate = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 2)];
                NSString *dbMediaOrNot = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 3)];

                Message *messege = [[Message alloc] initWithName:dbMessageText messageID:dbMessageID messageDate:dbMessageDate mediaOrNot:dbMediaOrNot];

                [messenges addObject:messege];

                [messege release];
            }
        }
        sqlite3_finalize(compiledStatement);
    }
    sqlite3_close(database);    
}

我的第一个 NSLog 向我展示了与数据库的连接是否正常。但下一步“从 MessagesData 中选择 *”并if(sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK) NSLog(@"connect to table OK"); else NSLog(@"connect to table FALSE");显示“连接到 FALSE 表”。尝试从我的数据库表中选择终端并得到错误“无法打开数据库文件”。我的错误在哪里?我在我的代码中没有看到任何问题......

4

3 回答 3

2

如果您打印返回的错误代码,sqlite3_prepare_v2则诊断问题会容易得多。数值可以在这个页面上找到。

int errorCode = sqlite3_prepare_v2(database, sqlStatement, -1, &compiledStatement, NULL);
if(errorCode != SQLITE_OK) {
    NSLog(@"Connect to table failed: %d", errorCode); 
}

但是,如果您甚至无法在sqlite3命令行工具中从数据库中进行选择,我建议您检查该文件是否存在、是否可读且格式是否正确。

尝试在您的模拟器中重现错误(如果失败,请将数据库文件复制到您的计算机,例如使用 Organizer)。尝试使用sqlite3(我知道您确实尝试过,但请确保您正在检查以下内容)运行查询。

如果您收到消息Error: file is encrypted or is not a database,则表示数据库文件已损坏。如果你得到Error: no such table:,这意味着你的数据库不存在,是空的,或者根本没有得到表。如果你得到(如你的问题):(Error: unable to open database你在打开 sqlite 期间得到这个,而不是在执行查询时得到),这意味着 sqlite 无法读取文件(例如权限)。

于 2012-04-09T11:59:47.213 回答
1

好吧,我猜你的数据库无法连接。从这里试试我的答案...

我在这里提到了几件事,我相信你会很好的

让我知道它有效

于 2012-04-09T14:02:01.740 回答
0

编写代码来检查表是否存在。在你执行查询选择之前,你应该检查创建表是否不存在......

NSLog(@"连接正常");

 sqlite3_exec(database,"CREATE TABLE IF NOT EXISTS MessagesData (ID INTEGER PRIMARY KEY AUTOINCREMENT ,"
                             "FirstName TEXT,LastName TEXT"));

   const char *sqlStatement = "select * from MessagesData";

如果它有效,请喜欢它

于 2012-04-09T12:06:35.727 回答