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

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

ただいまの
回答率

90.34%

  • JavaScript

    22124questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • HTML

    12608questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • CSS

    8387questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

  • データベース

    901questions

    データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

IndexedDBのopenCursor()で値が取得できずnullになる。

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 128

meuar

score 7

あるキーが含まれるデータのみ削除したいです。

createIndex()を使いキーを変更しており、そのあとopenCursor()でキーを指定したところ最初のデータのみ削除でき、その他のレコードは削除できずにnullが返ってきました。
その他のレコードも最初に取得できたデータとキーは一緒です。

回答をお願いします。

コード

function createDB() {
  var dbName = 'habitDB';

  //  DB名を指定して接続。指定したDB名がなければ新規作成。
  var openDb = indexedDB.open( dbName );
  //  DBの更新時のみ実行

  openDb.onupgradeneeded = function( event ) {

    var db = event.target.result;

    //  テーブルを生成
    db.createObjectStore( 'listTable', {keyPath: 'listId'} );
    var weekStore = db.createObjectStore( 'weekDayTable', {keyPath: ['listId', 'weekId']} );
    db.createObjectStore( 'recordTable', {keyPath: 'listId'} );
    var monthStore = db.createObjectStore( 'monthTable', {keyPath: ['listId', 'month']} ); 
    var toDoStore = db.createObjectStore( 'toDoTable', {keyPath: ['listId', 'toDoDate']} );

    //  index作成(引数1:名前, 引数2:キー名)
    toDoStore.createIndex( 'toDoStoreId', 'toDoDate',{unipue: false} );
    weekStore.createIndex( 'weekStoreId', 'listId',{unipue: false} );
    monthStore.createIndex( 'monthStoreId', 'listId', {unipue: false} );

    alert( 'DBを更新しました。' );

    //  接続解除
    db.close();
  }
}

          /*  keyが含まれるデータを削除する関数  */
//  key: DBのキー  name: createIndexの名前 table: DBのテーブル名
  this.deleteOnly = function( key, name, table ) {
    return new Promise( function( resolve, reject ) {
      var dbName = 'habitDB';
      var openDb = indexedDB.open( dbName );


      openDb.onsuccess = function( event ) {
        var db = event.target.result;
        var transaction = db.transaction( table, 'readwrite' );
        var store = transaction.objectStore( table );
        var index = store.index( name );
        index.getAll().onsuccess = function(event) {
          var test = event.target.result;
          for( var value of test ) {
            console.log(value);
          }
        }

        //  データ範囲の指定
        var cursor = index.openCursor( key, "next" );
        cursor.onsuccess = function( event ) {
          var result = event.target.result;
          if( result ) {
            console.log("削除");
            console.log(result.value);
            result.delete();
            result.continue();
          }else{
            resolve();
          }

        }

      };

    });
  }

データ例

listId Date flag
1 2019-01-01 false
1 2019-01-02 false
1 2019-01-03 false
1 2019-01-04 false
1 2019-01-05 false
2 2019-01-06 false

エラー例:キーを1で指定するとリストの一番上のレコードのみ削除されてしまう。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

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

  • ただいまの回答率 90.34%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • JavaScript

    22124questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • HTML

    12608questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • CSS

    8387questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

  • データベース

    901questions

    データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます