1. 原子性(Atomicity):
- 事务是一个原子操作,要么全部完成,要么全部失败。如果在事务执行过程中发生了错误,会回滚(Rollback)事务,使得数据库状态回到事务开始前的状态。
2. 一致性(Consistency):
- 事务执行前后,数据库的完整性约束没有被破坏。事务的执行使数据库从一个一致性状态转移到另一个一致性状态。
3. 隔离性(Isolation):
- 事务的执行是相互隔离的,即一个事务的执行不会影响其他事务的执行。这意味着在事务执行期间,其它事务看不到该事务的中间状态。
4. 持久性(Durability):
- 一旦事务完成提交,其对数据库的修改就是永久性的,即使发生系统故障,这些修改也会被保存。事务的提交使得所有已完成的更新永久地写入数据库。
数据库事务通过使用以下两个关键操作来实现:
- 提交(Commit):
- 提交操作将事务中的所有修改永久性地应用到数据库,并结束事务。提交之后,事务的修改将对其他事务可见。
- 回滚(Rollback):
- 回滚操作撤销事务中的所有修改,将数据库状态恢复到事务开始之前的状态。回滚通常在事务执行中出现错误时使用。
一个典型的事务示例可以如下:
BEGIN TRANSACTION;
-- 一系列数据库操作
UPDATE Account SET Balance = Balance - 100 WHERE AccountID = 1;
UPDATE Account SET Balance = Balance + 100 WHERE AccountID = 2;
-- 判断是否满足某个条件
IF SomeCondition
BEGIN
COMMIT; -- 提交事务
END
ELSE
BEGIN
ROLLBACK; -- 回滚事务
END
在上述示例中,BEGIN TRANSACTION 标志着事务的开始,一系列数据库操作在事务中执行,然后通过 COMMIT 提交事务,或者通过 ROLLBACK 回滚事务。
转载请注明出处:http://www.pingtaimeng.com/article/detail/186/数据库