質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

AngularJS

AngularJSはオープンソースのJavaScriptフレームワークです。ブラウザ上で動作するウェブアプリケーションの開発にMVCアーキテクチャを取り入れることを目的としています。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

Q&A

解決済

1回答

2234閲覧

monacaで、SQLITEのデータベースロックのエラーが出る。

neo01

総合スコア7

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

AngularJS

AngularJSはオープンソースのJavaScriptフレームワークです。ブラウザ上で動作するウェブアプリケーションの開発にMVCアーキテクチャを取り入れることを目的としています。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

0グッド

0クリップ

投稿2017/05/21 21:35

monaca + angular1 で、メモ帳アプリを作成中です。
sqliteを使い、データを保存しています。

順調に、データベースを参照出来ていたのですが、
ある時、SQL文で、外部参照している箇所で、
その対象テーブルをドロップしたところ、
データベースがロックしてしまいました。

通常のSELECT文を実行してみても、NGです。

monacaの他のプロジェクトをすべて消して、
作り直して、テーブルを参照するだけの
SELECT文でも、ロックは消えません。

解消方法は、ありますでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

CHERRY

2017/05/22 00:43

エラーメッセージは、表示されているそのままを記述してください。 テーブル名、カラム名などの特定されると困る部分は、 table1, c1, c2 などの適当な文字列で置き換えてください。
neo01

2017/05/22 21:49

CHERRYさん、ありがとうございます。 エラー内容は、Error occured while executing SQL: 5です。自己解決できました。ありがとうございました。
guest

回答1

0

自己解決

サブテーブルには、cardNameごとのサムネイルを設定するため、
PRIMARY KEYを二つを設定していましたが、
一つを削除しました。これにより、データベースロックが出なくなりました。

CHERRAYさん、ありがとうございました。

テーブル要件を見直してみます。

エラーメッセージ:
Error occured while executing SQL: 5

SQL文:
SQL = 'SELECT * , subTable.thumbnail '
+ 'FROM mainTable LEFT OUTER JOIN subTable ON '
+ '(mainTable.cards = subTable.cardName) ' +
'ORDER BY lastModify DESC';

コード:
var asyncProcess = function (SQL) {
var deferred = $q.defer();
$timeout(

function () { function queryDB(tx) { tx.executeSql(SQL, [], querySuccess, errorCB); } function querySuccess(tx, results) { deferred.resolve(results); } function errorCB(err) { console.log("Error occured while executing SQL: " + err.code); } var db = window.openDatabase("Database", "1.0", "cardsDatabase", 200000); db.transaction(function suc() { db.transaction(queryDB, errorCB); }, errorCB); }, 1); return deferred.promise;

};

投稿2017/05/22 21:54

neo01

総合スコア7

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問