美文网首页
MySQL——管理事务处理(十九)

MySQL——管理事务处理(十九)

作者: 开心糖果的夏天 | 来源:发表于2017-06-29 22:29 被阅读42次

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

    MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

    MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。由于其社区版的性能卓越,搭配 PHP 和 Apache 可组成良好的开发环境。

    一、事务处理

    事务处理是一种机制,用来管理必须成批执行的MySQL操作,以保证数据库不包含不完整的操作结果。利用事务处理,可以保证一组操作不会中途停止,它们或者作为整体执行,或者完全不执行(除非明确指示)。如果没有错误发生,整组语句提交给数据库表。如果发生错误,则进行回退(撤销)以恢复数据库到某个已知且安全的状态。

    事务处理需要知道的几个关键术语:
    (1)事务:指一组SQL语句;
    (2)回退:指撤销指定SQL语句的过程;
    (3)提交:指将未存储的SQL语句结果写入数据库表;
    (4)保留点:指事务处理中设置的临时占位符,可以对它发布回退。

    二、控制事务处理

    管理事务处理的关键在于将SQL与语句组分解为逻辑块,并明确规定数据何时应该回退,何时不应该回退。MySQL使用下边的语句标志事务的开始:

    START TRANSACTION;
    

    1.使用ROLLBACK

    MySQL的ROLLBACK命令用来回退(撤销)MySQL语句,示例如下:

    SELECT * FROM ordertotals;
    START TRANSACTION;
    DELETE FROM ordertotals;
    SELECT * FROM ordertotals;
    ROLLBACK;
    SELECT * FROM ordertotals;
    

    首先执行一条SELECT以显示该表不为空。然后开始一个事务处理,用一条DELETE语句删除ordertotals中的所有行。另一条SELECT语句验证ordertotals确实为空。这时用一条ROLLBACK语句回退START TRANSACTION之后的所有语句,最后一条SELECT语句显示该表不为空。

    2.使用COMMIT

    一般的MySQL语句都是直接针对数据库表执行和编写的。这就是所谓的隐含提交,即提交(写或保存)操作是自动进行的。但是,在事务处理块中,提交不会隐含的进行。为了明确的提交,使用COMMIT语句,如下所示:

    START TRANSACTION;
    DELETE FROM orderitems WHERE order_num=20010;
    DELETE FROM orders WHERE order_num=20010;
    COMMIT;
    

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

    3.使用保留点

    简单的ROLLBACK和COMMIT语句就可以写入或撤销整个事务处理。但是,只是对简单的事务处理才这样做,更复杂的事务处理可能需要部分提交或回退。

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

    SAVEPOINT deletel;
    

    每个保留点都取标识它的唯一名字,以便在回退时,MySQL知道要回退到何处。为了回退到刚才的保留点,可如下进行:

    ROLLBACK TO deletel;
    

    相关文章

      网友评论

          本文标题:MySQL——管理事务处理(十九)

          本文链接:https://www.haomeiwen.com/subject/syekcxtx.html