用哪一种实现事务处理的方法好呢?.docx

用哪一种实现事务处理的方法好呢?.docx

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
用哪一种实现事务处理的方法好呢? 现在,我们先采用数据库内部的事务处理存储过程来进行演示。通过在数据库服 务器中编写包含事务的存储过程,来完成对数据操作的事务处理了。同时,还要利用ADO 组件调用存储过程,也可以根据存储过程的返回代码判断事务处理是否执行成功。 前面我们已说过,在数据库系统中,每一条 SQL 语句都是一个事务。因此可以用它来保证每条语句要么执行成功,要么退到最初。但要一组 SQL 语句的操作也是这样, 就需要利用数据库的事务处理机制来实现。在数据库中生成存储过程的主要代码如下: Create proc RegisterUser (@usrName varchar(30), @usrPasswd varchar(30),@age int, @PhoneNum varchar(20), @Address varchar(50) ) as begin //显示定义并开始一个事务 begin tran insert into USER(userName,userPasswd) values(@usrName,@usrPasswd) if @@error0 begin //操作失败,事务退回rollback tran //返回存储过程,并设置返回码为事务操作失败return -1 end insert into USERDOC(userName,age,sex,PhoneNumber,Address) values(@Usrname,@age,@PhoneNum,@Address) if @@error0 begin //操作失败,事务退回 rollback tran return -1 end //如果操作执行正确,提交事务commit tran return 0 end 在 ASP 脚本中调用数据库存储过程的主要代码如下: % Set Comm=server.CreateObject (ADODB.Command) % % Set Comm.ActiveConnection=conn % % Comm.CommandType=adCmdStoredProc % % Comm.CommandText=RegisterUser % //创建存储过程返回参数对象 % Set RetCode=Comm.CreateParameter (RetCode,adInteger,adParamReturnValue) % //创建存储过程输入参数对象 % Set usrName=Comm.CreateParameter (usrName,adVarchar,adParamInput,30) % % Set usrPwd=Comm.CreateParameter (usrPasswd,adVarchar,adParamInput,30) % % Set age=Comm.CreateParameter(age,adInteger,adParamInput) % % Set PhoneNum=Comm.CreateParameter (PhoneNum,adVarchar,adParamInput, 20) % % Set Address=Comm.CreateParameter(Address,adVarchar,adParamInput,50) % % Comm.Parameters.Append usrName % % Comm.Parameters.Append usrPwd % % Comm.Parameters.Append age % % Comm.Parameters.Append PhoneNum % % Comm.Parameters.Append Address % % Comm.Parameters(usrName)=request (usrName) % % Comm.Parameters(usrPasswd)=request (usrPasswd) % % Comm.Parameters(age)=request(age) % % Comm.Parameters(PhoneNum)=request (PhoneNum) % % Comm.Parameters(Address)=request (Address) % % Comm.Execute % % RetValue=Cint(Comm(RetCode)) % //根据数据库存储过程返回代码判断注册是否成功 % if RetValue 0 then % % response.Redirect RegisterFail.html % % else % % response.Redirect RegisterOk.html % % end if % 好了,我

文档评论(0)

hao187 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体武汉豪锦宏商务信息咨询服务有限公司
IP属地上海
统一社会信用代码/组织机构代码
91420100MA4F3KHG8Q

1亿VIP精品文档

相关文档