返回介绍

8.10 事务控制也可以交给DBMS

发布于 2023-05-19 17:35:11 字数 979 浏览 0 评论 0 收藏 0

最后介绍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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文