sql必知必会哪个版本好,SQL必知必会-事物处理

 2023-09-22 阅读 15 评论 0

摘要:事物处理 使用事物处理(transaction processing),通过确保成批的SQL操作要么完全执行,要么完全不执行,来维护数据库的完整性。 关系数据库把数据存储在多个表中,使数据更容易操纵、维护和重用。 前面使用的Orders表就是一个很好的例子。订

事物处理

使用事物处理(transaction processing),通过确保成批的SQL操作要么完全执行,要么完全不执行,来维护数据库的完整性。
关系数据库把数据存储在多个表中,使数据更容易操纵、维护和重用。

前面使用的Orders表就是一个很好的例子。订单存储在Orders和OrderItems两个表中:Orders存储实际的订单,OrderItems存储订购的各项物品。这两个表使用称为主键的唯一 ID 互相关联,又与包含客户和产品信息的其他表相关联。
给系统添加订单的过程如下:

  1. 检查数据库中是否存在相应的顾客,如果不存在,添加他;
  2. 检索顾客的 ID ;
  3. 在Orders表添加一行,它与顾客 ID 相关联;
  4. 检索Orders表中赋予的新订单 ID ;
  5. 为订购的每个物品在OrderItems表中添加一行,通过检索出来的 ID 把它与Orders表关联(并且通过产品 ID 与Products表关联)。

sql必知必会哪个版本好,现在假设由于某种数据库故障(如超出磁盘空间、安全限制、表锁等),这个过程无法完成。数据库中的数据会出现什么情况?
如果故障发生在添加顾客之后,添加Orders表之前,则不会有什么问题。某些顾客没有订单是完全合法的。重新执行此过程时,所插入的顾客
记录将被检索和使用。可以有效地从出故障的地方开始执行此过程。但是,如果故障发生在插入Orders行之后,添加OrderItems行之前,怎么办?现在,数据库中有一个空订单。
更糟的是,如果系统在添加OrderItems行之时出现故障,怎么办?结果是数据库中存在不完整的订单,而你还不知道。

如何解决这种问题?这就需要使用事务处理了。事务处理是一种机制,用来管理必须成批执行的 SQL 操作,保证数据库不包含不完整的操作结果。利用事务处理,可以保证一组操作不会中途停止,它们要么完全执行,要么完全不执行(除非明确指示)。如果没有错误发生,整组语句提交给(写到)数据库表;如果发生错误,则进行回退(撤销),将数据库恢复到某个已知且安全的状态。

添加事务后的工作机制:

  1. 检查数据库中是否存在相应的顾客,如果不存在,添加他;
  2. 提交顾客信息;
  3. 检索顾客的 ID ;
  4. 在Orders表中添加一行;
  5. 如果向Orders表添加行时出现故障,回退;
  6. 检索Orders表中赋予的新订单 ID ;
  7. 对于订购的每项物品,添加新行到OrderItems表;
  8. 如果向OrderItems添加行时出现故障,回退所有添加的OrderItems行和Orders行。

关于事务的几个术语

sql server事务。事务(transaction)指一组SQL语句

回退(rollback)指撤销指定的SQL语句

提交(commit)指将未存储的SQL语句结果写入数据库表

sql事务语句?保留点(savepoint)指事物处理中设置的临时占位符(placeholder),可以对它发布回退,这与回退整个事务不同

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

控制事务处理

管理事务的关键在于将 SQL 语句组分解为逻辑块,并明确规定数据何时应该回退,何时不应该回退。

sql必知必会数据怎么下载,使用ROLLBACK,SQL的ROLLBACK命令用来回退(撤销)SQL语句

DELETE FROM Orders;
ROLLBACK;

此例子中,执行DELETE操作,然后用ROLLBACK语句撤销。
在事务处理块中,DELETE操作(与INSERT和UPDATE操作一样)并不是最终的结果。

使用COMMIT

一般的SQL语句都是针对数据库表直接执行和编写的。这就是所谓的隐式提交(implicit commit),即提交(写或保持)操作是自动进行的。在事务处理块中,提交不会隐式进行。不过有的DBMS会隐式提交处理事务。
进行明确的提交,使用COMMIT语句。

sql必知必会第4版pdf,SQL Server 的例子

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

在这个 SQL Server 例子中,从系统中完全删除订单12345。因为涉及更新两个数据库表Orders和OrderItems,所以使用事务处理块来保证订单不被部分删除。最后的COMMIT语句仅在不出错时写出更改。如果第一条DELETE起作用,但第二条失败,则DELETE不会提交。

Oracle 中完成相同的工作,可如下进行:

SET TRANSACTION
DELETE OrderItems WHERE order_num = 12345;
DELETE Orders WHERE order_num = 12345;
COMMIT;

使用保留点

使用简单的ROLLBACK和COMMIT语句,可以写入或撤销整个事务。但是,这只对简单的事务才能这么做,复杂的事物可能需要部分提交或回退。
例如前面描述的添加订单的过程就是一个事务。如果发生错误,只需要返回到添加Orders行之前即可。不需要回退到Customers表(如果存在的话)。

要支持回退部分事务,必须在事务处理块中的合适位置放置占位符。这样,如果需要回退,可以回退到某个占位符。
在 SQL 中,这些占位符称为保留点。在 MariaDB 、 MySQL 和 Oracle 中创建占位符,可使用SAVEPOINT语句:

SAVEPOINT delete1;

每个保留点都要取能够标识它的唯一名字,以便在回退时, DBMS 知道回退到何处。

SQL Server 中,如下进行:

SAVE TRANSACTION delete1;

MariaDB 、 MySQL 和 Oracle 中,如下进行:

ROLLBACK TO delete1;

完整的 SQL Server 例子:

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

这里的事务处理块中包含了 4 条INSERT语句。在第一条INSERT语句之后定义了一个保留点,因此,如果后面的任何一个INSERT操作失败,事务处理最近回退到这里。在 SQL Server 中,可检查一个名为@@ERROR的变量,看操作是否成功。(其他 DBMS 使用不同的函数或变量返回此信息。)如果@@ERROR返回一个非0的值,表示有错误发生,事务处理回退到保留点。如果整个事务处理成功,发布COMMIT以保留数据。

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

MYSQL事物

1.在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。
2.事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。
3.事务用来管理 insert,update,delete 语句

在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。

事务控制语句

1.BEGIN或START TRANSACTION显示的开启一个事务

2.COMMIT 也可以使用 COMMIT WORK,不过二者是等价的。COMMIT 会提交事务,并使已对数据库进行的所有修改成为永久性的;

3.ROLLBACK也可以使用ROLLBACK WORK,二者等价。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改

4.SAVEPOINT identifier,SAVEPOINT允许在事务中创建一个保存点,一个事务中可以有多个SAVEPOINT

5.RELEASE SAVEPOINT identifier删除一个事务的保存点。

6.ROLLBACK TO identifier把事务回滚到标记处

7.SET TRANSACTION 用来设置事务的隔离级别,InnoDB 存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ 和 SERIALIZABLE。

MYSQL 事务处理主要有两种方法:

1、用 BEGIN, ROLLBACK, COMMIT来实现

BEGIN 开始一个事务
ROLLBACK 事务回滚
COMMIT 事务确认
2、直接用 SET 来改变 MySQL 的自动提交模式:

SET AUTOCOMMIT=0 禁止自动提交
SET AUTOCOMMIT=1 开启自动提交

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/5/82297.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息