博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql中的锁
阅读量:7071 次
发布时间:2019-06-28

本文共 874 字,大约阅读时间需要 2 分钟。

主要介绍MyISAM的表锁和InnoDB的行锁

一:MyISAM的表锁

  1:设置读锁:lock table t_myisam_lock read;     unlock tables;//释放锁

  

  注:不要使用别名去查询,select lock.* from t_myisam_locak as lock,会报错。解决办法就是 lock table t_myisam_lock as a read,使用别名设置锁。

 

  2:设置写锁:lock table t_myisam_lock write;  unlock tables;//释放锁

     

  注:不要使用别名去查询,select lock.* from t_myisam_locak as lock,会报错。解决办法就是 lock table t_myisam_lock as a write,使用别名设置锁。

 

  共同点:

    只要是设置了读锁或者写锁,在同一个session对其他表都不能查询和修改,在不同session对其他表都能查询和修改。

  不同点:

    在同一session,读锁是能查询但不能修改,写锁是能查询、能修改。

    在不同session,读锁是能查询但是修改需要等待,写锁是能查询修改都需要等待。

 

二、innodb的行锁

  1:共享锁

    select * from 表名  where 条件  lock in share mode;

  2:排他锁

    select * from 表名  where 条件  for update;

    只会锁住这一行记录,操作其他的记录直接运行。操作该条记录会等待。

  注:锁住有索引的数据,会锁住查询的数据。没有索引的会锁住全部的数据。

  

  

  共享锁和排他锁的区别

  

 

  

三、innodb的表锁

  和myisam的表锁一样。不同点:开启一个新事务会释放表锁。

    

  

转载于:https://www.cnblogs.com/orange-time/p/10566022.html

你可能感兴趣的文章
android图片处理
查看>>
CentOS7中firewall防火墙详解和配置,.xml服务配置详解
查看>>
电子表格控件Spreadsheet 对象方法事件详细介绍
查看>>
自动填写短信验证码
查看>>
linux CentOS7最小化安装环境静默安装Oracle11GR2数据库(安装依赖包)
查看>>
运维自动化工具Cobbler之—标准化
查看>>
编译linux-3.15.5时遇到的几个错误
查看>>
nginx启动,重启,关闭命令
查看>>
redhat5.8+pam+mysql+vsftp(提供软件包可以到 百度云盘下载 账号 pankuo1@sina.cn 密码pk492940446)...
查看>>
支持Flash转换可打印的PDF文件的PDF转换控件ActivePDF WebGrabber
查看>>
JavaScript的一些概念: typeof, null, 和 undefined
查看>>
PL/SQL连接64位Oracle数据库
查看>>
关于Dr.Com3.73多人上网的破解(一)
查看>>
关于ChainCore开源区块链的Signer数量,Quroum配置
查看>>
mysqldump 备份数据库
查看>>
开启Pix ASA 5520 snmp协议
查看>>
Redhat镜像下载
查看>>
《数据结构与算法分析——c语言描述》读后笔记 7
查看>>
CheungSSH国产自动化运维工具开源Web界面
查看>>
mysql主从复制
查看>>