时间:2021-07-01 10:21:17 帮助过:21人阅读
transaction()函数有两个参数,并返回一个transaction对象。第一个参数是事务涵盖的对象store列表,(即事务的scope)。
如果您想让事务涵盖所有的对象store,您可以在此处指定一个空数组,但是请不要那样做,因为规范说了,空数组将引发 InvalidAccessError错误。如果您不指定第二个参数,默认地将使用read-only模式。如您想写数据库,请指定为readwrite。
现在您创建了事务,您需要了解它的生存期。事务与事件循环绑定的非常紧密。如果您创建了事务并返回给事件循环,
然而并没有使用,那么事务将变成非活动状态。让事务保持活动状态的唯一方法是在其上创建一个请求。当请求完成时,
您将得到一个DOM事件,将定请求是成功的,您将有新的机会在回调函数中扩展事务。如果您没有扩展事务就返回给了事务循环,事务将变成非活动状态,以此类推。只要存在等待期pending的请求,事务将保持活动状态。事务的生存期确实很简单,但是要掌握它还是需要一些时间的。更多一些例子,也会有助于理解。如果您已经开始阅读
TRANSACTION_INACTIVE_ERR错误码,就不合适了(因为还没理解事务的生存期)。
事务可以分为三种类型的DOM事件:error,abort,和complete。我们已经讨论了error事件的冒泡方式,因此,事务接受任何从它产生的请求抛出的error事件。更微妙的是,
error事件的默认行为是中止它所在的事务。除非您在错误处理中先调用stopPropagation()再执行其它处理,否则事务将回滚。这样的设计可以强制要求考虑和处理错误,但是
如果错误处理太冗长、琐碎,您可以在数据库对象上绑定一个错误处理。如果您没有处理错误事件,或者在事务上呼叫了Abort()函数,事务将回滚,事务的回滚事件将被触发。
或者,所有的等待期pending的请求都被处理完。您将得到一个Complete事件。如果您执行大量的数据库操作,那么跟踪事务而不是单个的请求,将有助于您理清思路。
现在您有事务了,您需要从中获取对象store。事务只是让您拥有当初创建事务时指定的那个对象store。然后您可以向对象store中添加数据了。
// Do something when all the data is added to the database.
transaction.oncomplete = function(event) {
alert("All done!");
};
transaction.onerror = function(event) {
// Don‘t forget to handle errors!
};
var objectStore = transaction.objectStore("customers");
for (var i in customerData) {
var request = objectStore.add(customerData[i]);
request.onsuccess = function(event) {
// event.target.result == customerData[i].ssn;
};
}
呼叫add()方法产生的请求结果是被添加的【键】的值。在此情况下,它应该等于被添加对象的ssn属性,因为对象store
使用ssn属性作为keypath。注意,add()方法要求在数据库中不能存在相同【键】的对象。如果您试图更改一个已存在的对象,或者您不关心是否存在该对象,您可以呼叫put()方法,如 Updating an entry in the database中所示。
删除数据
删除数据很简单:
var request = db.transaction(["customers"], "readwrite")
.objectStore("customers")
.delete("444-44-4444");
request.onsuccess = function(event) {
// It‘s gone!
};
查询数据
既然数据库中已经有数据了,您可以通过几种方法查询数据。首先,最简单的get()方法。您需要提供【key】来查询数
据,就像这样:
var transaction = db.transaction(["customers"]);
var objectStore = transaction.objectStore("customers");
var request = objectStore.get("444-44-4444");
request.onerror = function(event) {
// Handle errors!
};
request.onsuccess = function(event) {
// Do something with the request.result!
alert("Name for SSN 444-44-4444 is " + request.result.name);
};
对于一个“简单”查询来说,代码还是有点多啊。这里您可以让它更缩短一些,假定您在数据库层面处理了错误消息:
db.transaction("customers").objectStore("customers").get("444-44-4444").onsuccess = function(event) {
alert("Name for SSN 444-44-4444 is " + event.target.result.name);
};
看看它是如何工作的?因为只有一个对象store,您不用传递对象store列表,而只把对象store的名字给事务。而且,
您只是查询数据库,所以您不需要readwrite模式。呼叫transaction()方法默认的模式就是readonly。另一个微妙之处
在于您没有真正的把请求保存到一个变量。因为DOM事件把该请求request作为它的target,您可以使用event.target替代request。
注意,通过限制事务的作用域scope,和事务的模式,可以提高数据访问速度。
更新数据
现在我们查询到一些数据,更新它并插入IndexedDB数据库也很简单。我们把前面的例子改一下:
var objectStore = db.transaction(["customers"], "readwrite").objectStore("customers");
var request = objectStore.get("444-44-4444");
request.onerror = function(event) {
// Handle errors!
};
request.onsuccess = function(event) {
// Get the old value that we want to update
var data = event.target.result;
// update the value(s) in the object that you want to change
data.age = 42;
// Put this updated object back into the database.
var requestUpdate = objectStore.put(data);
requestUpdate.onerror = function(event) {
// Do something with the error
};
requestUpdate.onsuccess = function(event) {
// Success - the data is updated!
};
};
在这里我们创建一个objectStore,请求读出一个数据记录,使用【键】值ssn:444-44-4444。然后把查询结果存放在
变量data中,更改变量data的age属性值,再创建一个请求,把更改过的数据写回数据库,覆盖原来的结果。
注意:此时,我们必须指定readwrite模式的事务,因为要写入数据库内容,而不只是查询数据
使用indexedDB(二)(翻译)
标签:database 跟踪 定义 res ror dbi ref opera 结构