我是 phonegap android 应用程序的新手。(对不起我糟糕的英语。)
我想创建一个简单的应用程序,它有一个用于填充用户详细信息的搜索页面。我正在使用 Web 服务来获取用户的关系详细信息。在一个字段上,我想从数据库中搜索某种类型的静态代码。我们决定将它们存储在本地数据库而不是服务器中,以便搜索过程更快。我在创建数据库时遇到了一些问题。我只想在应用安装时创建一个时间数据库。我使用了以下代码。
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
var db = window.openDatabase("Database", "1.0", "Cordova Demo", 200000);
db.transaction(populateDB, errorCB, successCB);
}
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);
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);
}
// 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;
}
}
// 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);
}
所有数据都在 mySQL 数据库中的服务器上。当它安装在设备上时,我想将它们存储在应用程序中本地数据库的演示表中。
我有以下问题-
- 每次在设备中运行时,数据库都会覆盖演示表的行。
- 演示表在 mysql 数据库中有大约 15000 行。我可以进行 mysql 数据库表备份,但如何在应用程序数据库中恢复它。
- 我可以调用网络服务来存储安装时间的所有数据吗?
- 如果我使用本地存储,同样的问题。