5

ここに画像の説明を入力 これはデータベース フィールドの値です。

以下は、sqliteデータベースからデータを取得するために適用しているコードです

-(void)readDataFromRestaurantTable
{
    [self openDataBase];

    const char *dbpath = [databasePath UTF8String];

    if (sqlite3_open(dbpath, & database) == SQLITE_OK)
    {
        sqlite3_stmt  *statement = NULL;

        NSString *querySQL = [NSString stringWithFormat: @"SELECT * FROM RestaurantDB"];
        const char *query_stmt = [querySQL UTF8String];

        if (sqlite3_prepare_v2(database, query_stmt, -1, &statement, NULL) == SQLITE_OK) {

            while (sqlite3_step(statement) == SQLITE_ROW)
            {
                strRestaurantName = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 1)];
                strRestaurantAddress = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 2)];
                strRestaurantPhone = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 3)];
                strRestaurantLatitude = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 4)];
                strRestaurantLongitude = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 5)];

                NSLog(@"strRestaurantName :--> %@",strRestaurantName);
            }
        }
        sqlite3_finalize(statement);
    }
    sqlite3_close(database);
}

コード アプリケーションの前のブロックでは、

if (sqlite3_prepare_v2(database, query_stmt, -1, &statement, NULL) == SQLITE_OK)
{

}

ここでは、statement = 0x00000000を取得しています。この理由だけで、if ブロックに入っていないと思います。

クラッシュ時のエラー

Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** -[NSPlaceholderString initWithUTF8String:]: NULL cString'
First throw call stack:
(0x18dc012 0x12a1e7e 0x18dbdeb 0xcbdce6 0x78e4 0x7bdf 0x2ca817 0x2ca882 0x2ebed9 0x2ebd14 0x2ea1ea 0x2ea06c 0x2ebc57 0x12b5705 0x1ec920 0x1ec8b8 0x40f0b4 0x12b5705 0x1ec920 0x1ec8b8 0x2ad671 0x2adbcf 0x2ad6a6 0x412bb9 0x12b5705 0x1ec920 0x1ec8b8 0x2ad671 0x2adbcf 0x2acd38 0x21c33f 0x21c552 0x1fa3aa 0x1ebcf8 0x1da5df9 0x185ff3f 0x185f96f 0x1882734 0x1881f44 0x1881e1b 0x1da47e3 0x1da4668 0x1e965c 0x2712 0x2645 0x1)
libc++abi.dylib: terminate called throwing an exception

実際の問題がどこにあるのか教えてください。

4

5 に答える 5

8

これは、文字列で NSString オブジェクトを作成しようとしたことが原因NULLです。次のいずれかの行にあります。

[[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, ...)];

したがって、SQL ステートメントの結果で NSString を作成する前に、次のように NULL をチェックする必要があります。

char *tmp = sqlite3_column_text(statement, 1);
if (tmp == NULL)
    strRestaurantName = nil;
else
    strRestaurantName = [[NSString alloc] initWithUTF8String:tmp];
于 2013-01-31T05:23:42.503 に答える
2

次のようにバインドする前に、最初のデータがNULLであるかどうかを確認する必要があります:-

const char* date = (const char*)sqlite3_column_text(statement, 3);
NSString *enddate = date == NULL ? nil : [[NSString alloc] initWithUTF8String:date];

以下のメソッドでそれを実装します。

-(void)readDataFromRestaurantTable {

    [self openDataBase];
    if (sqlite3_open([databasePath UTF8String], &database) == SQLITE_OK) 
     {

        const char *sql = "SELECT * FROM RestaurantDB";
        sqlite3_stmt *selectstmt;
        if(sqlite3_prepare_v2(database, sql, -1, &selectstmt, NULL) == SQLITE_OK) 
            {

                while(sqlite3_step(selectstmt) == SQLITE_ROW) 
                {

                strRestaurantName = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 1)];
                strRestaurantAddress = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 2)];
                strRestaurantPhone = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 3)];
                strRestaurantLatitude = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 4)];
                strRestaurantLongitude = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 5)];

               }
        }
    }
    else
        sqlite3_close(database); //Even though the open call failed, close the database connection to release all the memory.
}

それはあなたを助けるかもしれません:)

于 2013-01-31T05:30:19.143 に答える
1

私の場合、db テーブルの最初の列「regno」をスキップすると、同じエラーが発生します。しかし、最初の列ヘッダー 'regno' を追加し、メソッド内で NSString として宣言すると、エラーが解消されました。

`-(NSArray*)loadData {

     const char *dbpath = [databasePath UTF8String];

    if (sqlite3_open(dbpath, &database) == SQLITE_OK) {
        NSString *querySQL = [NSString stringWithFormat:@"select regno, firstname, middlename, lastname, gender, dob, bloodgroup, mobileno, emailid from personalDetails"];

        NSMutableArray *resultArray = [[NSMutableArray alloc]init];
        const char *query_stmt = [querySQL UTF8String];

        if (sqlite3_prepare_v2(database, query_stmt, -1, &statement, NULL) == SQLITE_OK )
        {

            if (sqlite3_step(statement) == SQLITE_ROW) {

                ***NSString *regNo = [[NSString alloc] initWithUTF8String:
                                       (const char *) sqlite3_column_text(statement, 0)];
                [resultArray addObject:regNo];***


                NSString *firstname = [[NSString alloc] initWithUTF8String:
                                       (const char *) sqlite3_column_text(statement, 1)];
                [resultArray addObject:firstname];
                NSString *middlename = [[NSString alloc] initWithUTF8String:
                                        (const char *) sqlite3_column_text(statement, 2)];
                [resultArray addObject:middlename];
                NSString *lastname = [[NSString alloc]initWithUTF8String:
                                      (const char *) sqlite3_column_text(statement, 3)];
                [resultArray addObject:lastname];
                NSString *gender = [[NSString alloc]initWithUTF8String:
                                    (const char *) sqlite3_column_text(statement, 4)];
                [resultArray addObject:gender];
                NSString *dob = [[NSString alloc]initWithUTF8String:
                                 (const char *) sqlite3_column_text(statement, 5)];
                [resultArray addObject:dob];
                NSString *bloodgroup = [[NSString alloc]initWithUTF8String:
                                        (const char *) sqlite3_column_text(statement, 6)];
                [resultArray addObject:bloodgroup];
                NSString *mobileno = [[NSString alloc]initWithUTF8String:
                                      (const char *) sqlite3_column_text(statement, 7)];
                [resultArray addObject:mobileno];
                NSString *emailid = [[NSString alloc]initWithUTF8String:
                                     (const char *) sqlite3_column_text(statement, 8)];
                [resultArray addObject:emailid];


                return resultArray;
            }
            else{
                NSLog(@"Not found");
                return nil;
            }
            sqlite3_reset(statement);




        }
    }


    return nil;
}'
于 2016-05-30T10:52:56.270 に答える
1

条件sqlite3_finalize(statement);内に次のように記述します。if

 if (sqlite3_prepare_v2(database, query_stmt, -1, &statement, NULL) == SQLITE_OK)
 {

        while (sqlite3_step(statement) == SQLITE_ROW)
        {
            strRestaurantName = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 1)];
            strRestaurantAddress = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 2)];
            strRestaurantPhone = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 3)];
            strRestaurantLatitude = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 4)];
            strRestaurantLongitude = [[NSString alloc] initWithUTF8String:(const char *) sqlite3_column_text(statement, 5)];

            NSLog(@"strRestaurantName :--> %@",strRestaurantName);
        }
     sqlite3_finalize(statement);
 }
于 2013-01-31T06:17:17.253 に答える