范文 |
julyclyde(原作) 作者系2月份微软社区之星microsoft china community star 在编程中,经常需要使用事务。所谓事务,就是一系列必须都成功的操作,只要有一步操作失败,所有其他的步骤也必须撤销。比如用asp开发一个网络硬盘系统,其用户注册部分要做的事有: 将用户信息记入数据库 为用户开个文件夹用于存储 初始化用户操作日志 这三步必须使用事务,否则万一磁盘操作失败,而没有撤销数据库操作,就会造成只能登陆而不能操作的“死用户”现象。 由于数据库系统特殊的发展历史,小至access,大到db2,无不带有事务支持。因此上述步骤可以如下表示: on error resume next 第一步: 在事务环境下把用户信息记入数据库 if err then 关闭连接 退出 else 第二步:创建文件夹 if err then 回滚第一步数据库操作,退出 else 第三步:在事务环境下操作日志数据库 if err then 回滚第一步操作,删除第二步建立的文件夹 退出 end if end if end if 提交第一步数据库操作的事务 提交第二步数据库操作的事务 end 每一步都需要进行判断,如果失败,还需要手工回滚前面多步操作,使程序变得复杂、难懂。如果今后更新了程序,增加其他步骤,还需要嵌套 |