zoukankan      html  css  js  c++  java
  • 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限定主键,或主键处于某一范围内,如<>

  • 相关阅读:
    使用Putty和Xshell远程登录之密钥认证
    保护SSH的三把锁
    C++11_shared_ptr
    C++11_ tuple
    C++11_ 右值引用
    C++11_ Variadic Templates
    C++11_ Lambda
    C++11_新语法
    MoreEffectiveC++Item35 条款27: 要求或禁止对象产生于heap中
    MoreEffectiveC++Item35 条款26: 限制某个class所能产生的对象个数
  • 原文地址:https://www.cnblogs.com/itfenqing/p/4429396.html
Copyright © 2011-2022 走看看