0

次のコードを使用して、SQLite でデータベースを開き、挿入クエリを実行しています。

// Open the database and store the handle as a data member
if (sqlite3_open([databaseFile UTF8String], &databaseHandle) == SQLITE_OK)
{

    const char *sqlStatement = [insertStmt cStringUsingEncoding:NSUTF8StringEncoding];
    char *error;

    if (sqlite3_exec(databaseHandle, sqlStatement, NULL, NULL, &error) == SQLITE_OK)
    {
        NSLog(@"Config table values inserted.");
        registration_done = YES;
    } 
    else 
    {
        NSLog(@"Error: %s", error);
        [[NSRunLoop currentRunLoop] runUntilDate:[NSDate dateWithTimeIntervalSinceNow:1]]; 

        if (sqlite3_exec(databaseHandle, sqlStatement, NULL, NULL, &error) == SQLITE_OK) {
            NSLog(@"Config table values inserted 2.");
            registration_done = YES;
        } 
        else {
            NSLog(@"Error: %s", error);
        }
    }
}
else{

    sqlite3_close(databaseHandle);
}

sqlite3_close(databaseHandle);

しかし、次のエラーが発生し、アプリはその後終了しています:

-[__NSCFType UTF8String]: 認識されないセレクターがインスタンス 0x15d9a0 に送信されました

Phonegap(2.1.0) を使用しているため、データベース ファイルとテーブルは /Caches/ ディレクトリに作成されます。Phonegap は、上記の Objective-C コードが呼び出される前にクエリを適切に実行します。これは、テーブルが /Caches/ ディレクトリに正常に作成されていることを意味します。

4

2 に答える 2

0

@clint:- このURLを読んでください

または この例を試してください これは実際に機能しています

<!DOCTYPE html>
<html>
  <head>
    <title>Contact Example</title>

    <script type="text/javascript" charset="utf-8" src="phonegap-1.2.0.js"></script>
    <script type="text/javascript" charset="utf-8">

    // Wait for PhoneGap to load
    //
    document.addEventListener("deviceready", onDeviceReady, false);

    // Populate the database 
    //
    function populateDB(tx) {
        tx.executeSql('DROP TABLE IF EXISTS DEMO');
        tx.executeSql('CREATE TABLE IF NOT EXISTS DEMO (id unique, data)');
        tx.executeSql('INSERT INTO DEMO (id, data) VALUES (1, "First row")');
        tx.executeSql('INSERT INTO DEMO (id, data) VALUES (2, "Second row")');
    }

    // Query the database
    //
    function queryDB(tx) {
        tx.executeSql('SELECT * FROM DEMO', [], querySuccess, errorCB);
    }

    // Query the success callback
    //
    function querySuccess(tx, results) {
        var len = results.rows.length;
        console.log("DEMO table: " + len + " rows found.");
        for (var i=0; i<len; i++){
            console.log("Row = " + i + " ID = " + results.rows.item(i).id + " Data =  " + results.rows.item(i).data);
        }
    }

    // Transaction error callback
    //
    function errorCB(err) {
        console.log("Error processing SQL: "+err.code);
    }

    // Transaction success callback
    //
    function successCB() {
        var db = window.openDatabase("Database", "1.0", "PhoneGap Demo", 200000);
        db.transaction(queryDB, errorCB);
    }

    // PhoneGap is ready
    //
    function onDeviceReady() {
        var db = window.openDatabase("Database", "1.0", "PhoneGap Demo", 200000);
        db.transaction(populateDB, errorCB, successCB);
    }

    </script>
  </head>
  <body>
    <h1>Example</h1>
    <p>Database</p>
  </body>
</html>
于 2012-10-03T11:26:27.860 に答える
0

使うだけ

const char *sqlStatement = [insertStmt UTF8String];
于 2012-10-03T06:50:09.610 に答える