• mysql的事务和select...for update


    一.mysql的事务
    mysql的事务有两种方式:
    1.SET AUTOCOMMIT=0;也就是关闭了自动提交,那么任何commit或rollback语句都可以触发事务提交;如果SET AUTOCOMMIT=1;也就是开启了自动提交(默认值),那么必须要以begin或者START TRANSACTION声明事务的开始,然后再以commit或rollback语句都可以触发事务提交

    $db->query('SET autocommit=0');
    $db->query('update member set money=money+'.$money.' where memberId='.$memberId);
    $db->query('insert into mem_log(money) values('.$money.')');
    $db->query('commit');
    $db->query('insert into test(str) values('.sql_encode($msg).')');//该条数据无法插入。因为autocommit=0

    注意,在事务结束。要恢复autocommit的值。

    2.显示打开一个事务,就比上面的方法要简单些,不需要设置autocommit的值,也不用在事务结束后恢复autocommit的值。即,如果想保留autocommit开关打开,则通过begin或者START TRANSACTION声明事务,声明后,autocommit开关将会被禁用,直到您使用COMMIT或ROLLBACK结束事务为止,事务结束,autocommit开关将被打开。

    $db->query('START TRANSACTION');  
    $db->query('update member set money=money+'.$money.' where memberId='.$memberId);  
    $db->query('insert into mem_log(money) values('.$money.')');  
    $db->query('commit');  
    $db->query('insert into test(str) values('.sql_encode($msg).')');//该条数据可以插入

    二.SELECT...FOR UPDATE
    1.SELECT...FOR UPDATE用在事务中,处于begin和commit段内。该项将会锁定行,直到其他事务更新该行后才进行查询。这将保证数据更改的唯一性

    2.在以下情况下,SELECT...FOR UPDATE讲锁定整个InnoDB表:
    WHERE条件的字段不是主键,或用LIKE限定主键,或主键处于某一范围内,如<>

  • 相关阅读:
    头文件<stdarg.h>
    头文件<signal.h>
    头文件<setjmp.h>
    头文件<math.h>
    头文件<locale.h>
    头文件<limits.h>
    头文件<ctype.h>
    头文件<assert.h>
    PHP error_reporting
    八大排序算法
  • 原文地址:https://www.cnblogs.com/itfenqing/p/4429396.html
Copyright © 2020-2023  润新知