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

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

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

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

Q&A

解決済

1回答

433閲覧

Indexed Databaseにおけるキーの一意性について

taka_oct092018

総合スコア136

JavaScript

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

0グッド

0クリップ

投稿2021/11/07 09:26

編集2021/11/09 11:11

「HTML5プロフェッショナル認定試験 レベル2 対策テキスト&問題集 Ver2.0対応版」でJavaScriptを勉強しております
P315にあるコードの内容が分かりません。
自分なりの解釈は以下の通りです。

(statement01)
1.bookオブジェクトストアはキーとしてisbnプロパティを使用している。
2.isbnは一意である。

これで合ってますでしょうか?
よろしくお願い致します。

function indexDataBase(){ var indexedDB = window.indexedDB; var request = null; var db = null; var store = null; var transaction = null; request = indexedDB.open('books', 1); request.onupgradeneeded = function(){ db = request.result; store = db.createObjectStore('book', {keyPath:'isbn'}); // statement01 titleIndex = store.createIndex('by_title', 'title', {unique:false}); authorIndex = store.createIndex('by_author', 'author'); store.put({title:'Quarry Memories', author:'Fred', isbn:123456}); }; request.onsuccess = function(){ db = request.result; transaction = db.transaction('book', 'readwrite'); store = transaction.objectStore('book'); store.put({title:'Quarry Memories', suthor:'Fred', isbn:234567}); }; } indexDataBase();
問題点を検証するために作ったコード。 function indexDataBase(){ var indexedDB = window.indexedDB; var request = null; var db = null; var store_01 = null; var transaction_01 = null; var titleIndex_01 = null; var authorIndex_01 = null; var store_02 = null; var transaction_02 = null; var titleIndex_02 = null; var authorIndex_02 = null; request = indexedDB.open('books', 1); request.onupgradeneeded = function(){ db = request.result; store_01 = db.createObjectStore('book_01', {keyPath:'isbn_01'}); titleIndex_01 = store_01.createIndex('by_title_01', 'title_01', {unique:false}); authorIndex_01 = store_01.createIndex('by_author_01', 'author_01'); store_02 = db.createObjectStore('book_01', {keyPath:'isbn_01'}); titleIndex_02 = store_02.createIndex('by_title_02', 'title_02', {unique:false}); authorIndex_02 = store_02.createIndex('by_author_02', 'author_02'); store_01.put({title_01:'Quarry Memories_01', author_01:'Fred_01', isbn_01:123456_01}); store_02.put({title_02:'Quarry Memories_02', author_02:'Fred_02', isbn_01:123456_02}); }; request.onsuccess = function(){ db = request.result; transaction_01 = db.transaction('book_01', 'readwrite'); store_01 = transaction_01.objectStore('book_01'); transaction_02 = db.transaction('book_01', 'readwrite'); store_02 = transaction_02.objectStore('book_01'); store_01.put({title_01:'Quarry Memories_01', author_01:'Fred_01', isbn_01:234567_01}); store_02.put({title_02:'Quarry Memories_02', author_02:'Fred_02', isbn_01:234567_02}); }; } indexDataBase();

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

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

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

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

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

m.ts10806

2021/11/07 09:35

同じisbnでインサートするようなコードを書いてみては?
taka_oct092018

2021/11/09 11:13

m.ts10806様 返信ありがとうございます。 あえて主キーが重複するコードを書いて実行してみました。 予想通り、以下のエラーが発生して正常に作動しませんでした。 「Uncaught DOMException: Failed to execute 'createObjectStore' on 'IDBDatabase': An object store with the specified name already exists. at IDBOpenDBRequest.request.onupgradeneeded」 「store_01 = db.createObjectStore('book_01', {keyPath:'isbn_01'});」により、 「KeyPath isbn_01」は一意性があることを証明出来たということになり得ますでしょうか。
guest

回答1

0

ベストアンサー

Indexed Database APIの仕様により、キーは一意とされています。

There can never be multiple records in a given object store with the same key.

https://w3c.github.io/IndexedDB/#object-store-construct

投稿2021/11/09 23:52

itepechi

総合スコア248

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

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

taka_oct092018

2021/11/13 05:32

itepechi様 回答ありがとうございます。 とても良く分かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問