• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > mysql SELECT FOR UPDATE语句使用示例

mysql SELECT FOR UPDATE语句使用示例

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了mysql update select,mysql select db,mysql select,mysql select into,mysql select语句等相关知识,希望本文的分享对您有所帮助

以MySQL 的InnoDB 为例,预设的Tansaction isolation level 为REPEATABLE READ,在SELECT 的读取锁定主要分为两种方式:
SELECT ... LOCK IN SHARE MODE SELECT ... FOR UPDATE
这两种方式在事务(Transaction) 进行当中SELECT 到同一个数据表时,都必须等待其它事务数据被提交(Commit)后才会执行。而主要的不同在于LOCK IN SHARE MODE 在有一方事务要Update 同一个表单时很容易造成死锁 。
简单的说,如果SELECT 后面若要UPDATE 同一个表单,最好使用SELECT ... UPDATE。
举个例子: 假设商品表单products 内有一个存放商品数量的quantity ,在订单成立之前必须先确定quantity 商品数量是否足够(quantity>0) ,然后才把数量更新为1。
不安全的做法:

此时products 数据中id=3 的数据被锁住(注3),其它事务必须等待此次事务 提交后才能执行
SELECT * FROM products WHERE id=3 FOR UPDATE 如此可以确保quantity 在别的事务读到的数字是正确的。

MySQL SELECT ... FOR UPDATE 的Row Lock 与Table Lock
上面介绍过SELECT ... FOR UPDATE 的用法,不过锁定(Lock)的数据是判别就得要注意一下了。由于InnoDB 预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL 才会执行Row lock (只锁住被选取的数据) ,否则MySQL 将会执行Table Lock (将整个数据表单给锁住)。
举个例子:
假设有个表单products ,里面有id 跟name 二个栏位,id 是主键。
例1: (明确指定主键,并且有此数据,row lock)
</div>

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MySQL SELECT同时UPDATE同一张表问题发生及解决
  • 10个mysql中select语句的简单用法
  • mysql 一次更新(update)多条记录的思路
  • mysql SELECT FOR UPDATE语句使用示例
  • 解析mysql与Oracle update的区别

相关文章

  • 2018-12-05Xampp服务器上的mysql密码修改图文步骤
  • 2017-05-11mysql把一个表某个字段的内容复制到另一张表的某个字段的SQL语句写法
  • 2018-12-05ACCESS 调用后台存储过程的实现方法
  • 2018-12-05后盾网MySQL数据库视频教程资源推荐
  • 2018-12-05MySQL数据库添加新用户详解
  • 2018-12-05返回SQL执行时间的存储过程
  • 2017-09-08Mysql 数据库给表添加字段
  • 2018-12-05JDBC--数据库管理系统
  • 2017-05-11Mysql数据表分区技术PARTITION浅析
  • 2018-12-05SQL连接查询介绍

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包)
    • win2003上安装SQL2000时CD-KEY(序列号)无法验证解决方法
    • MySQL里的found_row()与row_count()的解释及用法
    • Mysql 错误问题汇总(不断更新中)
    • MongoDB学习笔记《一》
    • 如何测试mysql触发器和存储过程
    • mssql 指定字段编号sql语句
    • MySQL数据库如何开启远程连接(多备份)
    • mysql进阶(二十一)删除表数据
    • MySQL锁机制和PHP锁机制

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有