2012-02-03 27 views
0

我也跟着有关创建SQLite数据库,插入数据,并从中寻找数据的教程和使用下面的方法来从数据库中提取数据:如何从sqlite中提取名称的数据搜索?

-(IBAction)findContacts{ 

    const char *dbpath = [databasePath UTF8String]; 
    sqlite3_stmt *statement; 
    if (sqlite3_open(dbpath, &contactDB)==SQLITE_OK) { 
     NSString *querySQL = [NSString stringWithFormat:@"SELECT adress, phone FROM CONTACTS WHERE name = \"%@\"", [name text]]; 
     status.text = querySQL;   
     const char *query_stmt = [querySQL UTF8String]; 

     if (sqlite3_prepare_v2(contactDB, query_stmt, -1, &statement, NULL) == SQLITE_OK) { 
      if (sqlite3_step(statement)==SQLITE_ROW) { 

       NSString *adressField = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 0)]; 
       adress.text = adressField; 

       NSString *phoneField = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 1)]; 
       phone.text = phoneField; 

       status.text = @"Match Found"; 

       [adressField release]; 
       [phoneField release];} 

        status.text = @"Match not Found"; 
        adress.text = @""; 
        phone.text = @""; 
      sqlite3_finalize(statement);} 
     sqlite3_close(contactDB);}} 

当我编译,没有错误!没有注意!但不工作...

,我发现那是什么,因为

sqlite3_prepare_v2(contactDB, query_stmt, -1, &statement, NULL) == SQLITE_OK) 

是不相等的,代码不是如果statemens得到英寸我发现,当我扭转的情况与

sqlite3_prepare_v2(contactDB, query_stmt, -1, &statement, NULL) != SQLITE_OK) 

和锯在status.text“匹配未找到”。但仍然无法找到任何真正的联系。

你知道代码有什么问题吗?

在此先感谢...

回答

1

你真的不想进入块,除非“sqlite3_prepare_v2”的结果实际上是SQLITE_OK。

将平等要求更改为'!='是一个有趣的诊断,但显然它不是应该永久保留在测试代码中的更改。

现在我们知道sqlite3_prepare_v2没有返回成功的代码,问的问题是:什么代码确实它返回?

根据该文件,它必须返回此处显示的代码之一:

http://sqlite.org/c3ref/c_abort.html

您还可以使用“sqlite3_errmsg”得到一个字符串表示。请参阅:http://sqlite.org/c3ref/errcode.html

+0

解决你的帮助。感谢que que ... :) – Karaca 2012-02-03 16:24:38