前面写过一篇:本地存储和数据库的文章,没基础的先看一下这里。不然你看着会懵。
还是回到我出文章的思路来
关于索引和游标,我会问
1、索引的API有哪些?
2、索引应该怎么使用?有哪些好处?
3、游标的API有哪些?
4、游标怎么使用?有哪些用途?
5、两位可以一起使用吗?
第一个问题:索引的API有哪些?
IDBObjectStore.createIndex() --------创建索引
该方法接收三个参数:
indexName ----索引名称
keyPath ---- 索引字段,可以为空或者数组
optionsParameters ---- 索引配置参数
关于optionsParameters的配置参数有:
1、unique表示keyPath字段的数据是否是唯一的
2、multiEntry表示是否为keyPath字段的每一项建立一条索引数据。(有点懵没关系,下面会有演示)
第二个问题:索引应该怎么使用?有哪些好处?
data:image/s3,"s3://crabby-images/bcd52/bcd520d5fe5c14cf573697f1c0fdfd2253dbfce0" alt=""
data:image/s3,"s3://crabby-images/56f4e/56f4e3c1727fca8e90cd725d9167c77c694f8cec" alt=""
data:image/s3,"s3://crabby-images/d404d/d404da648e85db5c6664590f6469e1c6ad1e46d5" alt=""
data:image/s3,"s3://crabby-images/efc67/efc6756ecf3bce8d3c5b53d64b6e75a36bc4d394" alt=""
data:image/s3,"s3://crabby-images/e5d93/e5d93c853e6be07a1e5ad53ed0d73c5e96595424" alt=""
使用创建索引的好处在于:
1、可以使用存储记录中的值作为索引(不用创建多余的数据,提高效率)
2、索引会自动更新
3、索引数据自动排序
第三个问题:游标的API有哪些?
第四个问题:怎么使用
IDBObjectStore/IDBIndex.openCursor() -----创建游标
该方法返回一个IDBRequest对象,这个对象的结果返回IDBCursorWithValue对象。
可选参数有两个,
第一个是range----顾名思义是取值范围的意思。
一般值的写法是:IDBKeyRange.bound(key1,key2)
IDBKeyRange.only(key)
第二个direction----数据排列方向的意思
direction的话取值有四个,两个比较常用的prev和next
演示一下
data:image/s3,"s3://crabby-images/49e52/49e52995ec1f5025314d1073e4143aa2b53e6be3" alt=""
data:image/s3,"s3://crabby-images/21f1d/21f1d291b8f4cd291371c1eed48ee15766597341" alt=""
data:image/s3,"s3://crabby-images/93345/9334535f211415213bcdbd8f5f2d9ca4c46d9d4b" alt=""
data:image/s3,"s3://crabby-images/f7a5d/f7a5d17a588c73064d850af5c782f99ea2b2f112" alt=""
第五个问题:游标和索引的结合使用
1、更新数据
data:image/s3,"s3://crabby-images/e1a83/e1a836377ef2fffc9fcccb817d60da4447a98fef" alt=""
data:image/s3,"s3://crabby-images/60e20/60e20d6fc5a4db64425fbae4b95dc1122100a403" alt=""
data:image/s3,"s3://crabby-images/68179/68179ee36602cac33033de95e94df3ac83e948e2" alt=""
2、删除对应字段的数据
data:image/s3,"s3://crabby-images/a29d6/a29d62fe46b133a10c79161a5b4801486953cc9b" alt=""
data:image/s3,"s3://crabby-images/ab771/ab771aefe55964856c0d3bf58988fdaf7aca24c1" alt=""
如有侵权,联系作者删
网友评论