可以使用游标找到 IndexedDB 对象,但不能通过 get(key)
Can find IndexedDB object using cursor but not by get(key)
最初我编写这段代码是为了使用其键搜索 'section' 对象:
var section = {};
var getSection = store.get(id);
getSection.onsuccess = function(e){
section = e.target.result;
}
但是无法找到该对象(部分为 "undefined"),即使通过浏览器检查具有相应键的对象显然存在。此外,以下代码 确实有效:
var section = {};
var transaction = db.transaction(['section'], 'readonly');
var store = transaction.objectStore('section');
var index = store.index("section_id");
index.openCursor().onsuccess = function(e){
var cursor = e.target.result;
if (cursor){
if (cursor.value['section_id'] == id){
section = cursor.value;
}
cursor.continue();
}
}
它产生相同的结果,但后者要慢得多。我想要第一种工作方式。为什么不是?
作为参考,这是我对 "section" 的 objectStore 定义:
if (!thisdb.objectStoreNames.contains("section")){
var objectStore = thisdb.createObjectStore("section", {keyPath:"section_id"});
// Add properties
objectStore.createIndex("section_id", "section_id", {unique:true});
objectStore.createIndex("catalog_num", "catalog_num", {unique:false});
objectStore.createIndex("title", "title", {unique:false});
objectStore.createIndex("dow", "dow", {unique:false});
objectStore.createIndex("meeting_days", "dow", {unique:false});
objectStore.createIndex("start_time", "start_time", {unique:false});
objectStore.createIndex("end_time", "end_time", {unique:false});
objectStore.createIndex("instructor", "instructor", {unique:false});
objectStore.createIndex("section", "section", {unique:false});
objectStore.createIndex("room", "room", {unique:false});
objectStore.createIndex("overview", "overview", {unique:false});
objectStore.createIndex("requirements", "requirements", {unique:false});
objectStore.createIndex("univ_num", "univ_num", {unique:false});
objectStore.createIndex("term_id", "term_id", {unique:false});
objectStore.createIndex("course_symbol", "course_symbol", {unique:false});
如果未定义,是因为没有找到值。您的对象库是如何配置的?您将什么定义为关键?我认为这将是一个问题。
您可以尝试使用 store.index('section_id').get(id);
而不是 store.get(id);
作为快速修复。鉴于您的键路径被定义为指向 section_id,这似乎很奇怪,因为我也希望开始工作。
第二个问题可能是数据类型冲突。你在混合字符串和数字吗?你是存储字符串然后按数字查询,还是类似的东西?因为您的游标示例使用 ==
类型不敏感。要快速测试,请尝试使用 ===
进行光标测试,看看它是否仍然有效。如果失败,您很可能正在做一些事情,比如将 id 存储为字符串,然后使用数字 id 进行查询。
最初我编写这段代码是为了使用其键搜索 'section' 对象:
var section = {};
var getSection = store.get(id);
getSection.onsuccess = function(e){
section = e.target.result;
}
但是无法找到该对象(部分为 "undefined"),即使通过浏览器检查具有相应键的对象显然存在。此外,以下代码 确实有效:
var section = {};
var transaction = db.transaction(['section'], 'readonly');
var store = transaction.objectStore('section');
var index = store.index("section_id");
index.openCursor().onsuccess = function(e){
var cursor = e.target.result;
if (cursor){
if (cursor.value['section_id'] == id){
section = cursor.value;
}
cursor.continue();
}
}
它产生相同的结果,但后者要慢得多。我想要第一种工作方式。为什么不是?
作为参考,这是我对 "section" 的 objectStore 定义:
if (!thisdb.objectStoreNames.contains("section")){
var objectStore = thisdb.createObjectStore("section", {keyPath:"section_id"});
// Add properties
objectStore.createIndex("section_id", "section_id", {unique:true});
objectStore.createIndex("catalog_num", "catalog_num", {unique:false});
objectStore.createIndex("title", "title", {unique:false});
objectStore.createIndex("dow", "dow", {unique:false});
objectStore.createIndex("meeting_days", "dow", {unique:false});
objectStore.createIndex("start_time", "start_time", {unique:false});
objectStore.createIndex("end_time", "end_time", {unique:false});
objectStore.createIndex("instructor", "instructor", {unique:false});
objectStore.createIndex("section", "section", {unique:false});
objectStore.createIndex("room", "room", {unique:false});
objectStore.createIndex("overview", "overview", {unique:false});
objectStore.createIndex("requirements", "requirements", {unique:false});
objectStore.createIndex("univ_num", "univ_num", {unique:false});
objectStore.createIndex("term_id", "term_id", {unique:false});
objectStore.createIndex("course_symbol", "course_symbol", {unique:false});
如果未定义,是因为没有找到值。您的对象库是如何配置的?您将什么定义为关键?我认为这将是一个问题。
您可以尝试使用 store.index('section_id').get(id);
而不是 store.get(id);
作为快速修复。鉴于您的键路径被定义为指向 section_id,这似乎很奇怪,因为我也希望开始工作。
第二个问题可能是数据类型冲突。你在混合字符串和数字吗?你是存储字符串然后按数字查询,还是类似的东西?因为您的游标示例使用 ==
类型不敏感。要快速测试,请尝试使用 ===
进行光标测试,看看它是否仍然有效。如果失败,您很可能正在做一些事情,比如将 id 存储为字符串,然后使用数字 id 进行查询。