web-dev-qa-db-ja.com

PhoneGapアプリにデータベースを実装する方法は?

私はこれが初めてで、AndroidとiOSの両方に対して、PhoneGapで展開するアプリを構築しようとしています。タイムテーブルデータを格納するデータベースにリンクする方法を考えています。 。

私の質問は、PhoneGapでパッケージできるようにデータベースを含める方法です。

PhoneGapのドキュメントを確認しましたが、データベースの設定方法や作成方法については、あまり意味がありません。


更新:このウェブサイトはローカルストレージに関する情報を表示しますが、それを置くと、ロード中の画像でハングします。

さらなるアイデアは?

http://www.aquim.com/web-article-237.html

12
Mathias

Sq-liteを使用した簡単な操作については、以下のリンクを参照してください。また、上からStorage APIの基本的なアイデアを入手できます link

Sq-liteによる簡単な操作: http://www.raymondcamden.com/index.cfm/2011/10/20/Example-of-PhoneGaps-Database-Support

2013年5月8日に編集、2016年1月19日に修正

DBでの基本操作:

<script type="text/javascript" charset="utf-8" src="cordova-x.x.x.js"></script>
<script type="text/javascript" charset="utf-8">
// Wait for Cordova to load
document.addEventListener("deviceready", onDeviceReady, false);

// Cordova is ready
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!");
}
</script>

refrence

ファイルエクスプローラでデータベースを確認できます

ADTバンドルウィンドウで>>ビューを表示>>ファイルエクスプローラー

14
MSTdev

PhoneGapには、HTML5ローカルストレージを直接使用する代わりに使用するストレージAPIがあります。 AndroidとiOSの両方で、ネイティブ実装を使用します。

http://docs.phonegap.com/en/2.7.0/cordova_storage_storage.md.html#Storage を参照してください

1
GreyBeardedGeek

Android Gingerbread 2.3.3エミュレータのデータベースのmaxSizeは65535でなければならないので注意してください。

このOS 200000 maxSizeでは、エラーが発生する可能性があります。

200000 maxSizeは新しいOSで動作します。

0