51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1131|回复: 8
打印 上一主题 下一主题

数据库事务备忘录

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2007-2-17 14:36:06 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
事务是指一组相互依赖的操作行为,举例子就是银行交易,当然还有其他像网上购物,电子货币交易等等,事务的成功取决于这些相互依赖的操作行为是否都能执行成功,只要有一个操作行为失败,就意味着整个事务失败。
例如:bill和tom的QQ账户的QQ币点数都是500点,现在bill把100点QQ币转到tom的QQ币账号上,
这个事务就包含以下操作行为:

     ---- bill的QQ币账号减少100点
     ---- tom的QQ币账号增加100点

     这两个操作作为一个不可分割的工作单元,假如仅仅第一步操作执行成功,但是第二步执行失败,那么整个事务失败,回滚到事务开始前的状态,bill和tom的QQ账户的QQ币点数还依然是500点。显然如果没有事务的概念,那么就会造成bill的100点QQ币神秘的消失了...数据库的事务就是上面提到的事务在RDB中的实现,
它由一组在业务逻辑上相互依赖的SQL语句组成,假设以上QQ账户在DB中的qq_account表结构如下:
        ------------------------------------   
             id       name      balance
        ------------------------------------
             1         bill           500
             2         tom          500
        ------------------------------------

     以上事务的SQL可以表示为:
        UPDATE qq_account SET balance=400 WHERE id=1;
        UPDATE qq_account SET balance=600 WHERE id=2;

    只要两条SQL语句有一个执行失败,整个事务就失败,
qq_account表中的数据就必须回退到最初的状态,而不会被更新。

[ 本帖最后由 51sky18 于 2007-4-4 22:28 编辑 ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

9#
 楼主| 发表于 2007-4-4 22:30:19 | 只看该作者
谢谢 Song Fun版主 ...嘿嘿.
不好意思把标题写错了~~sdlkfj1
已经改了过来sdlkfj5
回复 支持 反对

使用道具 举报

该用户从未签到

8#
发表于 2007-4-3 18:53:11 | 只看该作者
终于让我把事务理解了,谢谢哈。
回复 支持 反对

使用道具 举报

该用户从未签到

7#
发表于 2007-4-3 12:17:50 | 只看该作者
不错嘛。。。思路很清晰的。。。
回复 支持 反对

使用道具 举报

该用户从未签到

6#
发表于 2007-3-15 00:25:05 | 只看该作者
同学的标题写错了:事务,非事物,呵呵
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2007-3-12 10:27:55 | 只看该作者
sdlkfj5  太棒了
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2007-3-2 17:38:30 | 只看该作者
researched
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2007-2-28 12:54:54 | 只看该作者
好帖,通俗易懂,不错不错!
回复 支持 反对

使用道具 举报

该用户从未签到

2#
 楼主| 发表于 2007-2-17 14:38:18 | 只看该作者
数据库事务必须具备ACID特性,具体的含义:

     ----- Atomic(原子性):只整个数据库事务是不可分割的工作单元。只有事务中所有的操作执行成功,才算整个事务成功;事务中任何一个SQL语句执行失败,那么已经执行成功的SQL语句也必须撤销,数据库状态应该退回到执行事务前的状态。

     ----- Consistency(一致性):指数据库事务不能破坏关系数据的完整性以及业务逻辑上的一致性。
例如,不管上面的例子里面QQ币转账的事务成功还是失败,都应该保证事务结束后qq_account表中bill和tom的QQ币总额为1000点。

     ----- Isolation(隔离性):指的是在并发的环境之中,当不同的事务同时操作相同的数据时,每个事务都有各自的完整数据空间,这里涉及的事情就多了,我想在后面单独总结成一篇文章。

     ----- Durability(持久性):指的是只有事务成功结束,它对数据库所做的更新就必须永久保存下来。即使发生系统崩溃,重新启动数据库后,
数据库还能恢复到事务成功结束时的状态。
回复 支持 反对

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-18 16:33 , Processed in 0.067883 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表