sql >> Databasteknik >  >> RDS >> SQLite

Uncaught TypeError kan inte anropa metoden 'opendatabase' för undefined-SQLite plugin med cordova 3.5

Uttrycket i din kod kommer att misslyckas om du inte har inkluderat sqlite-plugin i ditt projekt.

var db = window.sqlitePlugin.openDatabase({name: "test.db"});

Du bör också vänta på att deviceready-händelsen ska avfyras innan du använder cordova-plugins.
Du kan använda window.openDatabase() anrop som skapar sqlite DB och inte behöver sqlite-plugin.
Nedan är koden för att använda openDatabase-anropet i din app.

om din sqlite-plugin fungerar korrekt, ändra då db-anropet till.

var db = window.sqlitePlugin.openDatabase({name: "test.db"});

kod som inte använder sqlite-plugin.

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

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

    // 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")');
    }

    // Transaction error callback
    //
    function errorCB(err) {
        alert("Error processing SQL: "+err);
    }

    // Transaction success callback
    //
    function successCB() {
        alert("success!");
    }

Ovanstående kodavsnitt är hämtat från Cordova API-dokument. Se här för detaljer. Även om dokumentationen är för 3.0 bör den fungera för 3.5




  1. MONTH() Exempel – MySQL

  2. Installera pg gem; FEL:Det gick inte att bygga ädelstensinbyggt tillägg

  3. Vad gör sp_reset_connection?

  4. FALLSTUDIE:ARKWARE MS ACCESS CRM