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限定主键,或主键处于某一范围内,如<>

  • 相关阅读:
    xcode8.3 shell 自动打包脚本
    MarkDown常用语法记录
    正则表达式matcher.group()用法
    使用Jenkins进行持续集成
    Java8新特性:Stream的使用
    zookeeper windows 下配置和基础命令
    JAVA文件中获取路径及WEB应用程序获取路径方法
    共享锁(S锁)和排它锁(X锁)
    zookeeper 官方文档——综述
    zookeeper 入门指导
  • 原文地址:https://www.cnblogs.com/itfenqing/p/4429396.html
Copyright © 2011-2022 走看看