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

  • 相关阅读:
    Android Studio导入第三方类库的方法
    转:[Android Studio 权威教程]最实用的快捷键
    转[Android Studio 权威教程]配置出“NB”的Android Studio
    Android中对list的日期元素进行排序
    Unable to resolve target 'android-XX'
    Android WebView 获取网页的标题
    button设置点击更改背景图片 转
    android 跳转 系统浏览器的方法
    android学习笔记之调用拨号界面拨打电话
    自定义dialog无黑色边框
  • 原文地址:https://www.cnblogs.com/itfenqing/p/4429396.html
Copyright © 2011-2022 走看看