indexedDB 查詢資料
本章節將通過程式碼例項介紹一下indexedDB資料庫如何去查詢資料。
屬於可資料庫增刪改查操作中的一項基本操作,查詢方式很多,大致羅列如下:
(1).indexedDB 通過主鍵查詢指定資料一章節。
(2).indexedDB 通過索引查詢指定資料一章節。
(3).indexedDB 獲取物件倉庫所有資料一章節。
(4).indexedDB 遍歷資料一章節。
(5).indexedDB 查詢指定區間資料一章節。
考慮到篇幅問題,本文進隊第一種查詢方法進行詳細介紹,其他方式可以參閱對應文章。
首先看一段程式碼例項:
[HTML] 純文字檢視 複製程式碼執行程式碼<!doctype html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>螞蟻部落</title> <script> let students=[ { id:1001, name:"張三", age:21, sex:"男" },{ id:1002, name:"李四", age:20, sex:"女" },{ id:1003, name:"王五", age:19, sex:"女" } ]; let request = window.indexedDB.open("antzone", 1); request.onupgradeneeded = (ev) => { let db = ev.target.result; if (!db.objectStoreNames.contains('students')) { let objectStore = db.createObjectStore('students',{keyPath:"id"}); objectStore.createIndex("xingbie","sex",{ unique: false }); objectStore.createIndex("xingming","name",{ unique: true }); } } request.onsuccess = (ev) => { let db = ev.target.result; let odiv=document.getElementById("ant"); let transaction = db.transaction(['students'], 'readwrite'); let objectStore = transaction.objectStore('students'); for(let i=0;i<students.length;i++){ objectStore.add(students[i]); } let getRequest = objectStore.get(1002); getRequest.onsuccess=function(ev){ odiv.innerHTML=this.result.name; } getRequest.onerror=function(ev){ odiv.innerHTML="讀取失敗"; } } </script> </head> <body> <div id="ant"></div> </body> </html>
程式碼執行效果截圖如下:
程式碼分析如下:
(1).通過倉庫物件的get()方法可以獲取物件主鍵資料。
(2).get()方法的引數是主鍵值。
(3).此方法是一個非同步操作,返回值是一個IDBRequest型別物件。
(4).通過監聽IDBRequest物件的success事件可以判斷讀取資料是否已經成功。
關於get方法的具體用法可以參閱IDBObjectStore.get() 方法一章節。
上述是通過物件倉庫物件的get()方法查詢指定主鍵資料,IDBIndex物件同樣具有get()方法。
關於IDBIndex物件的get()方法可以參閱indexedDB 通過索引查詢指定資料一章節。
相關文章
- indexedDB 通過索引查詢資料Index索引
- indexedDB 更新資料Index
- indexedDB 新增資料Index
- MySQL - 資料查詢 - 簡單查詢MySql
- IndexedDB 資料庫新增資料Index資料庫
- indexedDB 遍歷資料Index
- indexedDB 資料庫 索引Index資料庫索引
- indexedDB 刪除資料Index
- indexedDB 批量新增資料Index
- indexedDB 資料庫版本Index資料庫
- IndexedDB 資料庫概述Index資料庫
- IndexedDB 資料庫用法Index資料庫
- Java ——MongDB 插入資料、 模糊查詢、in查詢Java
- 資料庫高階查詢之子查詢資料庫
- RESTFul資料查詢REST
- MYSQL查詢資料MySql
- AMS 資料查詢
- 資料庫基礎查詢--單表查詢資料庫
- elasticsearch查詢之大資料集分頁查詢Elasticsearch大資料
- indexedDB 刪除資料庫Index資料庫
- indexedDB 資料庫主鍵Index資料庫
- SSH:hiberate實現資料的查詢(單查詢和全查詢)
- indexedDB 增刪改查Index
- Jemter查詢資料庫資料庫
- Flask——資料的查詢Flask
- 求助:資料庫查詢資料庫
- ThinkPHP 資料庫查詢PHP資料庫
- 資料庫排序查詢資料庫排序
- 查詢資料庫大小資料庫
- shell查詢prometheus資料Prometheus
- MySQL資料庫基礎——多表查詢:子查詢MySql資料庫
- 20240719資料庫關聯查詢、條件查詢資料庫
- Logtail:像查詢資料庫一樣查詢日誌AI資料庫
- MongoDB資料庫中查詢資料(下)MongoDB資料庫
- 資料庫查詢語句資料庫
- Laravel 查詢某天資料 whereDateLaravel
- mysql將查詢資料另存MySql
- 資料庫查詢優化資料庫優化