1

phonegap アプリに sqlite データベースを使用しています。

私はこのようなことを試みます:

アプリの初回起動時にテーブルを作成します。

tx.executeSql('CREATE TABLE IF NOT EXISTS SETTINGS (id unique,data)');

その後、最初の行のアイテムを取得します:

var returnwert = results.rows.item(0).data;

そのコードは次のエラーを生成します。

Item index is out of range!

テーブルにデフォルト値がないため、その理由はわかっています。

ダフルト値を持つテーブルを作成するにはどうすればよいですか?

そんな感じ:

 tx.executeSql('CREATE TABLE IF NOT EXISTS SETTINGS (id unique 1, 2, 3,data defaultvalue="test")');

3 つの行を持つ SETTINGS という名前のテーブルは、次のようになります。

id = 0 data = test
id = 1 data = test
id = 2 data = test

誰かが私を助けることができますか

4

3 に答える 3

1

テーブルを作成するには、おそらく次のようなことを意味していました。

CREATE TABLE IF NOT EXISTS settings (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    data VARCHAR(128)
)

テーブルにいくつかの値を入力するには、次のステートメントを使用します。

REPLACE INTO settings VALUES (1, 'test');
REPLACE INTO settings VALUES (2, 'test');
REPLACE INTO settings VALUES (3, 'test');

初めて実行すると、id 1,2,3 の行が作成されます。

2 回目に実行すると、ID 1、2、3 の行が上書きされます。

上書きしたくない場合は、次INSERT OR IGNOREのように使用します。

INSERT OR IGNORE INTO settings VALUES (1, 'test');
...
于 2013-02-18T07:17:24.617 に答える
0

以下のコードを試して、新しいデータベースを開き、そこから値を挿入して読み取ります。

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

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

    // Wait for Cordova 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) {
  console.log("Returned rows = " + results.rows.length);
  // this will be true since it was a select statement and so rowsAffected was 0
  if (!results.rowsAffected) {
    console.log('No rows affected!');
    return false;
  }
  // for an insert statement, this property will return the ID of the last inserted row
  console.log("Last inserted row ID = " + results.insertId);
    }

    // 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", "Cordova Demo", 200000);
        db.transaction(queryDB, errorCB);
    }

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

    </script>
  </head>
  <body>
    <h1>Example</h1>
    <p>Database</p>
  </body>
</html>
于 2013-02-18T09:46:19.573 に答える
0

問題は、sqlite テーブルの作成にあります。

  tx.executeSql('CREATE TABLE "SETTINGS" ("id" INTEGER PRIMARY KEY  AUTOINCREMENT  NOT    NULL , "DATA" TEXT NOT NULL);',
                  null,
                  function(){/* to do on success */},
                  function(){/* to do on fail */}
);

次に、挿入時に次のクエリを使用する必要があります。

tx.executeSql("INSERT INTO \"book\" VALUES(1,'test');",null,function(){/* to do on success */},function(){/* to do on fail */});
tx.executeSql("INSERT INTO \"book\" VALUES(2,'test');",null,function(){/* to do on success */},function(){/* to do on fail */});
tx.executeSql("INSERT INTO \"book\" VALUES(3,'test');",null,function(){/* to do on success */},function(){/* to do on fail */});

phonegapのドキュメンタリーはいつでも参照できます

于 2013-02-18T07:17:02.510 に答える