侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

HTML5 客户端数据库简易使用:IndexedDB

数据库  /  管理员 发布于 6年前   182

IndexedDB介绍

IndexedDB是一种能在浏览器中持久的存储结构化数据的对象数据库,并且为web应用提供了丰富的查询能力。

相比于Web SQL数据库它更加简单,而且官方标准中关于Web SQL的工作已经停止。

相比于Web Storage,IndexedDB存储空间是无上限且永久的。

创建数据库

IndexedDB是按域名分配独立空间,一个独立域名下可以创建多个数据库,每个数据库可以创建多个对象存储空间(表/对象仓库),一个对象存储空间可以存储多个对象数据(索引的字段)。

function openDB(){    var request = indexedDB.open(dbName,dbVer);//如果数据库存在就打开,如果数据库不存在就去新建    request.onsuccess = function(e){    }    request.onerror = function(e){    }    //创建新数据库,或者数据库版本号被更改的时候出发onupgradeneeded事件,并执行回调函数    request.onupgradeneeded = function(e){}}

indexedDB.open方法用于创建数据库,里面传两个参数(数据库名,数据库版本),request.onupgradeneeded方法在创建新数据库,或者数据库版本号改变时调用

创建对象存储空间

request.onupgradeneeded = function(e){        db = e.target.result;        //判断是否有这个对象仓库的存在        if(!db.objectStoreNames.contains('Users')){//如果对象仓库不存在,创建一个新的对象仓库(keyPath,主键 ; autoIncrement,是否自增),会返回一个对象(objectStore)var store = db.createObjectStore('Users',{keyPath:'id',autoIncrement:true});//指定可以被索引的字段,unique字段是否唯一,可以创建多个索引store.createIndex('username','username',{unique:false})        }    }

store.createIndex创建索引字段,里面传三个参数(索引命名,索引字段,是否唯一)

事务(transaction)

对IndexedDB的查询和更新都是包含在一个事务(transaction)中,以此来保证这些操作要么一起成功,要么一起失败。

function dataHandle(data){    //创建事务对象    var ts = db.transaction('Users','readwrite');    //通过事务对象获取对象仓库    var store = ts.objectStore('Users');    //向仓库添加数据    var req = store.put(data);    req.onsuccess = function(){}}

对仓库store的操作:

  • put()添加数据,参数为要保存的对象,如果数据主键(keypath)已存在相同的则更改数据。
  • add()添加数据,参数为要保存的对象,如果数据主键(keypath)已存在相同的则保存失败。
  • delete()删除数据,传入参数为目标数据的主键。get()获取数据,传入参数为目标数据的主键。

遍历数据

通过游标cursor检索范围内的对象仓库中的数据

var range = IDBKeyRange.lowerBound(1);//指定游标检索范围var req = store.openCursor(range);//创建游标dbData = [];req.onsuccess = function(){    var cursor = this.result;    if(cursor){        dbData.push(cursor.value);        cursor.continue();//循环读取数据直到结束    }else{}}

IDBKeyRange主要的几个方法:

  • IDBKeyRange.bound(n1, n2, false, false); 范围从n1到n2的主键,第三四个参数为是否包含n1或n2
  • IDBKeyRange.only(n);范围一个主键
  • IDBKeyRange.lowerBound(n, false);大于n的主键集合
  • IDBKeyRange.upperBound(n, false);小于n的主键集合

查询数据

能被查询的数据需要被store.createIndex()创建过索引

    var store = ts.objectStore('Users');    var index = store.index("username");//打开数据库索引    var range = IDBKeyRange.only(keyName);//传递一个单键(索引的值)获取range    var req = index.openCursor(range);

删除数据库

indexedDB.deleteDatabase("数据库名称");

总结

以上完成了创建数据库,创建对象储存空间,通过事务对数据进行遍历,添加,查询的操作。代码地址Demo地址 ,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    mysql分页性能探索
    下一条:
    详解Ubuntu下安装mysql和简单操作
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 分库分表的目的、优缺点及具体实现方式介绍(0个评论)
    • DevDB - 在 VS 代码中直接访问数据库(0个评论)
    • 在ubuntu系统中实现mysql数据存储目录迁移流程步骤(0个评论)
    • 在mysql中使用存储过程批量新增测试数据流程步骤(0个评论)
    • php+mysql数据库批量根据条件快速更新、连表更新sql实现(0个评论)
    • 近期文章
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-06
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-01
    • 2018-05
    • 2018-10
    • 2018-11
    • 2020-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2021-02
    • 2021-04
    • 2021-07
    • 2021-08
    • 2021-11
    • 2021-12
    • 2022-02
    • 2022-03
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-07
    • 2023-08
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客