zoukankan      html  css  js  c++  java
  • 21-事务

    事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性。

    举例说明:

    复制代码
    create table user2(
    id int primary key auto_increment,
    name char(32),
    balance int
    );
    
    insert into user2(name,balance)
    values
    ('wsb',1000),
    ('egon',1000),
    ('ysb',1000);
    
    
    #原子操作
    start transaction;
    update user2 set balance=900 where name='wsb'; #买支付100元
    update user2 set balance=1010 where name='egon'; #中介拿走10元
    update user2 set balance=1090 where name='ysb'; #卖家拿到90元
    commit;
    
    #出现异常,回滚到初始状态
    start transaction;
    update user2 set balance=900 where name='wsb'; #买支付100元
    update user2 set balance=1010 where name='egon'; #中介拿走10元
    uppdate user2 set balance=1090 where name='ysb'; #卖家拿到90元,出现异常没有拿到
    rollback;
    
    mysql> select * from user;
    +----+------+---------+
    | id | name | balance |
    +----+------+---------+
    |  1 | wsb  |    1000 |
    |  2 | egon |    1000 |
    |  3 | ysb  |    1000 |
    +----+------+---------+
    rows in set (0.00 sec)
    复制代码

    下面是操作:当p_return_code为1时,表示异常,立马回滚。当为2时,出现警告,立马回滚原始状态。0表示成功

    复制代码
    delimiter //
    create PROCEDURE b6(
        OUT p_return_code tinyint
    )
    BEGIN 
        DECLARE exit handler for sqlexception 
        BEGIN 
            -- ERROR 
            set p_return_code = 1; 
            rollback; 
        END; 
    
        DECLARE exit handler for sqlwarning 
        BEGIN 
            -- WARNING 
            set p_return_code = 2; 
            rollback; 
        END; 
    
        START TRANSACTION; 
            insert into blog(name,sub_time) values('yyy',now());
        COMMIT; 
    
        -- SUCCESS 
        set p_return_code = 0; #0代表执行成功
    
    END //
    delimiter ;
    
    set @res=123;
    call b6(@res);
    select @res;
    复制代码

     

  • 相关阅读:
    Mysql存储过程和函数
    python反编译chm文件并生成pdf文件
    python转换html到pdf文件
    python获取系统开机时间
    OpenSL ES: 利用OpenSL ES实现录音功能
    android: 根据文件uri 获取文件名
    Java: InputStream转化为byte数组
    Linux: 查看二进制文件
    Vim: 回到上次编辑的位置
    LayoutInflate: Avoid passing null as the view root
  • 原文地址:https://www.cnblogs.com/zsdbk/p/9196498.html
Copyright © 2011-2022 走看看