sql语法入门(四)

本文介绍了SQL中的事务处理,包括事务的概念、回退、提交和保留点,并提供了示例。同时,还讲解了游标的应用,如何创建和使用游标来在结果集中进行导航。
摘要由CSDN通过智能技术生成

管理事务处理
事务处理(transaction processing)可以用来维护数据库的完整性,它保证成批的SQL操作要么完全执行,要么完全不执行。

有关事务处理的几个概念

事务(transaction)指一组SQL语句;
回退(rollback)指撤销指定SQL语句的过程;
提交(commit)指将未存储的SQL语句结果写入数据库表;
保留点(savepoint)指事务处理中设置的临时占位符(placeholder),可以对它发布回退(与回退整个事务处理不同)。

提示:可以回退哪些语句?

事务处理用来管理INSERT、UPDATE和DELETE语句。不能回退SELECT语句(回退SELECT语句也没有必要),也不能回退CREATE或DROP操作。事务处理中可以使用这些语句,但进行回退时,这些操作也不撤销。

2. 控制实务处理
SQL Server要求明确标识事务处理块的开始和结束。如下:

 BEGIN TRANSACTION
 ...
 COMMIT TRANSACTION

2.1 使用ROLLBACK语句
在下面的示例中,执行DELETE操作,然后用ROLLBACK语句撤销

 DELETE FROM Orders;
 ROLLBACK;

2.2 使用COMMIT语句

 BEGIN TRANSACTION
 DELETE OrderItems WHERE order_num = 12345
 DELETE Orders WHERE order_num = 12345
 COMMIT TRANSACTION

2.3 使用保留点
使用简单的ROLLBACK和COMMIT语句,就可以写入或撤销整个事务。但是,只对简单的事务才能这样做,复杂的事务可能需要部分提交或回退。 要支持回退部分事务,必须在事务处理块中的合适位置放置占位符。这样,如果需要回退,可以回退到某个占位符。在SQL中,这些占位符称为保留点。

在SQL Server中设置占位符:

SAVE TRANSACTION delete1;

每个保留点都要取能够标识它的唯一名字,以便在回退时,DBMS知道回退到何处。要回退到本例给出的保留点,在SQL Server中这样还原:

ROLLBACK TRANSACTION delete1;

下面是一个使用占位符的完整示例

 BEGIN TRANSACTION
 INSERT INTO Customers(cust_id, cust_name)
 VALUES('1000000010', 'Toys Emporium');
 SAVE TRANSACTION StartOrder;
 INSERT INTO Orders(order_num, order_date, cust_id)
 VALUES(20100,'2001/12/1','1000000010');
 IF @@ERROR <> 0 ROLLBACK TRANSACTION StartOrder;
 INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
 VALUES(20100, 1, 'BR01', 100, 5.49);
 IF @@ERROR <> 0 ROLLBACK TRANSACTION StartOrder;
 INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
 VALUES(20100, 2, 'BR03', 100, 10.99);
 IF @@ERROR <> 0 ROLLBACK TRANSACTION StartOrder;
 COMMIT TRANSACTION

提示:保留点越多越好
可以在SQL代码中设置任意多的保留点,越多越好。为什么呢?因为保留点越多,你就越能灵活地进行回退。

游标(cursor)
SQL检索操作返回一组成为结果集的行。这组返回的行都是与SQL语句相匹配的行(零行或多行)。

结果集(result set):SQL查询所检索出的结果。

有时,需要在检索出来的行中前进或后退一行或多行。这就是使用游标的原因。

创建游标

DECLARE CURSOR CustCursor
IS
SELECT * FROM Customers
WHERE cust_email IS NULL;

使用游标

OPEN CURSOR CustCursor

关闭游标

CLOSE CustCursor
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值