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

  • 相关阅读:
    iOS本机生成证书请求文件流程
    NET开发必备工具之-LINQPad
    css3 地球自转公转
    css3 里外转 动画
    css动画,三片扇叶旋转
    max-height、min-height、height优先级的问题
    前端实现在线预览pdf、word、xls、ppt等文件
    原生js实现上传下载
    js通过拍照或相册选择图片后,做压缩处理
    原生js 手机端 调用 拍照、录像、录音、相册(含图片或视频)、音频文件等
  • 原文地址:https://www.cnblogs.com/itfenqing/p/4429396.html
Copyright © 2011-2022 走看看