如何用 IDBKeyRange 范围匹配检索特定区间的本地数据

IDBKeyRange 是 IndexedDB 中定义键范围的工具,用于配合 openCursor 或 getAll 精准查询区间数据,支持 only、bound、lowerBound、upperBound 四种构造方式,需注意键类型、索引依赖和字符串比较规则。IDBKeyRange 是 IndexedDB 中用于定义键范围的工具,能帮你精准查出落在某区间内的记录,比如"2023年1月到12月的订单"或"用户ID在 100 到 200 之间的数据"。它不直接执行查询,而是配合 objectStore.openCursor() 或 objectStore.getAll() 使用,告诉数据库"只处理这个范围里的键"。创建常见类型的 IDBKeyRange根据匹配逻辑不同,有四种基础构造方式:单点匹配:IDBKeyRange.only(key) ------ 只匹配完全相等的键,例如 IDBKeyRange.only(123) 左闭右闭区间:IDBKeyRange.bound(lower, upper, lowerOpen = false, upperOpen = false) ------ 默认包含端点,如 IDBKeyRange.bound(10, 20) 匹配 10、11...20 左开右闭/左闭右开:通过第三个、第四个布尔参数控制开闭,例如 IDBKeyRange.bound(10, 20, true, false) 匹配 11 到 20(不含 10) 单向范围:IDBKeyRange.lowerBound(10)(≥10)、IDBKeyRange.upperBound(100)(≤100),可加 true 参数表示不包含端点配合游标遍历区间数据这是最常用也最灵活的方式,适合大数据量或需要逐条处理的场景:const transaction = db.transaction('orders', 'readonly');const store = transaction.objectStore('orders');const range = IDBKeyRange.bound(new Date('2023-01-01'), new Date('2023-12-31'));store.openCursor(range).onsuccess = function(event) { const cursor = event.target.result; if (cursor) { console.log('订单ID:', cursor.key, '内容:', cursor.value); cursor.continue(); // 继续下一条 }};注意:游标默认按主键升序遍历;若索引字段是日期或数字,确保该字段已建索引且作为游标范围的依据(例如用 index.openCursor(range))。 幻导航网 发现优质实用网站,开启网络探索之旅!

相关推荐
麻雀飞吧2 分钟前
2026年期货量化入门路径:主流平台学习曲线与卡点观察
python
TechWayfarer2 分钟前
IP数据接口调用示例:社交软件如何做同城匹配与用户画像分析
python·网络协议·tcp/ip·社交电子
aqi005 分钟前
15天学会AI应用开发(二)为什么编写提示词这么重要
人工智能·python·大模型·ai编程·ai应用
_Evan_Yao5 分钟前
线性代数 + 编程:用Python实现向量和矩阵运算
python·线性代数·矩阵
曹牧8 分钟前
Oracle:UNIX时间戳
数据库·oracle·unix
XiaoLin laile13 分钟前
【无标题】
网络·数据库·人工智能
lili001217 分钟前
Claude自动修Bug配置优化与避坑指南
java·人工智能·python·bug·ai编程
逻极17 分钟前
Java 从入门到精通:核心原理、最佳实践与性能优化
java·jvm·并发编程·集合框架
Szime20 分钟前
靠谱的终端工厂采购电子元器件供应链哪家更适合研发型企业?
人工智能·python
2401_8734794026 分钟前
如何用IP离线库批量清洗订单IP,自动标注省市区?
开发语言·网络·python