查看: 7058|回复: 0
打印 上一主题 下一主题

ASP.NET中的事务处理和异常处理

[复制链接]
跳转到指定楼层
1#
发表于 2007-10-17 19:44:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
台州网址导航
使用SQL-Transaction类和.NET提供的异常处理机制,我们就能够以一种可靠的方式处理数据库运行中的问题和发现系统异常。这篇小文章将解释事务处理和异常处理的概念和用法。

什么是事务?

事务处理是由以一个单一的逻辑单位完成的一系列操作,它可以由一系列的SQL语句、SELECT、INSERT、UPDATE、DELETE组成,如果在该单位包含的操作执行完毕后没有发生错误,那么它对数据库所作的改变就是永久的了。如果一旦有错误发生,它就不会对数据库作任何修改或改变。

要定义一个事务,需要使用Begin tran命令,在这一命令之后的任何语句都将被认为是事务的一部分。命令Commit用来完成事务,并使事务对数据库所作的修改成为永久的。Rollback命令用来取消一个事务,并还原事务对数据库所作的修改。

下面是一个事务的例子:

[SQL SERVER7.0 or SQL SERVER2000]

 BEGIN TRAN

INSERT INTO PRODUCT(PRODUCTID, PRODUCTNAME) VALUES("0001", "KEYBOARD")

UPDATE PRODUCT SET PRICE=12 WHERE PRODUCTID= "0002"

IF (@ERROR>0)

 ROLLBACK

ELSE

 COMMIT

什么是异常处理?

开发一种错误消息处理机制、并向用户提供有用的、清楚、有意义的信息也是编程人员的任务之一,异常处理就是能够提供这一服务的一种机制。一旦事务失败,服务器就会向系统发出一个用于帮助用户发现并修复邦联的数据库错误信息。我们可以异常处理功能来获取这种异常信息,并修复出现的故障。

异常处理功能的用法如下所示:

[c#]

try

catch (Exception e)

finally

如何实现事务?

1、在一个存储过程中编写事务语句,并使用下面的控制发现是否有错误发生,返回相应的值,互联网应用程序会根据返回的值显示正确的和容易理解的错误信息。下面是一个事务的例子:

[Store Procedure]

CREATE PROCEDURE PRODUCT_SAVE( AS

DECLARE

(@USERID CHAR(5),

@LOCATION VARCHAR(50),

@RETURNS INT OUTPUT

)

BEGIN TRAN

UPDATE ADDRESS SET LOCATION=@LOCATION WHERE USERID=@USERID

IF (@@ERROR>0)

BEGIN

@RETURNS=-1 /* Fail to Update */

ROLLBACK

END

ELSE

@RETURNS=0 /* Succeed to update */

COMMIT

RETURN @RETURNS

[Web Application in C#]

int values;

DBClass dbc=new DBClass(); // 使用new命令生成一个数据库类

values=dbc.updatedb("0001", "23 Rain Street"); //And call its function member to update record

if (values==0)

Lable_message.text= "Update successfully";

else

Lable_message.text= "Sorry, can not update this record, please contact your DBA."
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖
台州维博网络(www.tzweb.com)专门运用PHP+MYSQL/ASP.NET+MSSQL技术开发网站门户平台系统等。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

网站推广
关于我们
  • 台州朗动科技(Tzweb.com)拥有多年开发网站平台系统门户手机客户端等业务的成功经验。主要从事:政企网站,系统平台,微信公众号,各类小程序,手机APP客户端,浙里办微应用,浙政钉微应用、主机域名、虚拟空间、后期维护等服务,满足不同企业公司的需求,是台州地区领先的网络技术服务商!

Hi,扫描关注我

Copyright © 2005-2026 站长论坛 All rights reserved

Powered by 站长论坛 with TZWEB Update Techonolgy Support

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