8.10 事务控制也可以交给DBMS
最后介绍DBMS的一个高级功能 – 事务控制。事务由若干条SQL语句构成,表示对数据库一系列相关操作的集合。有一个经典的银行账户间汇款的例子可用于说明其概念。为了从顾客A的账户中给顾客B的账户汇入1万元,就需要将以下两条SQL语句依次发送给DBMS:(1)把A的账户余额更新(UPDATE语句)为现有余额减去1万元;(2)把B的账户余额更新(UPDATE语句)为现有余额加上1万元。此时这两条SQL语句就构成了一个事务
假设在第一条SQL语句执行后,网络或计算机发生了故障,第二条SQL语句无法执行,会发生什么呢?A的账户余额减少了1万元,但B的账户余额却没有相应地增加1万元,这就导致了数据不一致。为了防止出现这种问题,在SQL语句中设计了以下三条语句:(1)BEGIN TRANSACTION(开启事务)语句,用于通知DBMS开启事务;(2)COMMIT(提交事务)语句,用于通知DBMS提交事务;(3)ROLL BACK(事务回滚)语句,用于在事务进行中发生问题时,把数据库中的数据恢复到事务开始前的状态(如图816所示)。
图8.16 事务的开启、提交和回滚
在使用ADO创建应用程序时,可以分别使用Connection类的Begin Trans、CommitTrans和Rollback Trans方法实现上述三个操作。DBMS真的是很方便,只要使用了DBMS,连事务管理这样的高级功能都不必自己实现了
计算机是一种工具,可以执行输入、计算、输出三种操作,并可以通过这一系列的操作处理某种数据。因此可以说计算机就是处理数据的装置。因此,可以说计算机基本上就是被当作数据库来利用的。只要不是游戏程序,几乎在所有的应用程序中,人们都在巧妙地运用着数据库。因此为了了解计算机,数据库是一门必修课
此外,为了了解计算机,网络也是与数据库不分伯仲的另一门必修课。在第9章,讲解网络相关的内容。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论