我在 indexeddb 对象存储上有两个属性的复合索引,并希望根据这两个属性的范围检索游标。
这是商店中的示例对象:
{species: 'Oak',xcoord: 123456, ycoord: 654321}
和索引:
treeStore.createIndex("treelocation", ["xcoord","ycoord"], { unique: false });
索引创建成功,我可以在 Chrome 开发者工具中看到它,但是现在我想打开一个在 x 和 y 坐标上都有键范围的光标(这将是 map 的范围).
在线搜索我看不到如何执行此操作,并且使用键范围数组打开索引似乎不起作用。
最佳答案
范围建议是答案的一部分,但即使使用数组键,它实际上也只是一维范围,而不是数据的 2 维(或 N 维)选择。使用您当前的架构,您需要执行以下操作:
index.openCursor([lowX, lowY], [highX, highY]).onsuccess = function(e) {
var cursor = e.target.result;
if (!cursor) return; // done!
var x = cursor.key[0], y = cursor.key[1];
// assert(lowX <= x && x <= highX);
if (y < lowY) {
cursor.continue([x, lowY]);
} else if (y > highY) {
cursor.continue([x + 1, lowY]);
} else {
processRecord(cursor.value); // we got one!
cursor.continue();
}
};
(如果坐标不是整数,请将 + 1
替换为适当的 epsilon)
我已经发布了一个通用解决方案的示例:
关于javascript - 多个属性上的索引数据库游标范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16522115/