IndexedDB 是键值(文档)存储。它没有 JOIN 查询或对多个对象存储的查询。但是,您可以在一个事务中查询多个商店。这就是在 IndexedDB 中进行连接查询的方式。
我有一点写建模关系http://dev.yathit.com/ydn-db/schema.html http://dev.yathit.com/ydn-db/schema.html使用我的图书馆。
这是加入查询SELECT * FROM Supplier, Part WHERE Supplier.CITY = Part.CITY
.
var iter_supplier = new ydn.db.IndexValueIterator('Supplier', 'CITY');
var iter_part = new ydn.db.IndexValueIterator('Part', 'CITY');
var req = db.scan(function(keys, values) {
var SID = keys[0];
var PID = keys[1];
console.log(SID, PID);
if (!SID || !PID) {
return []; // done
}
var cmp = ydn.db.cmp(SID, PID); // compare keys
if (cmp == 0) {
console.log(values[0], values[1]);
return [true, true]; // advance both
} else if (cmp == 1) {
return [undefined, SID]; // jump PID cursor to match SID
} else {
return [PID, undefined]; // jump SID cursor to match PID
}
}, [iter_supplier, iter_part]);
查看更多详细信息加入查询文章 http://dev.yathit.com/ydn-db/doc/query/join-query.html.