MySQL 锁表

1.FLUSH TABLES WITH READ LOCK

这个命令是全局读锁定,执行了命令之后所有库所有表都被锁定只读。一般都是用在数据库联机备份,这个时候数据库的写操作将被阻塞,读操作顺利进行。

解锁的语句也是unlock tables。

 

2.LOCK TABLES tbl_name [AS alias] {READ [LOCAL] | [LOW_PRIORITY] WRITE}

这个命令是表级别的锁定,可以定制锁定某一个表。例如: lock  tables test read; 不影响其他表的写操作。

解锁语句也是unlock tables。

 

这两个语句在执行的时候都需要注意个特点,就是 隐式提交的语句。在退出mysql终端的时候都会隐式的执行unlock tables。也就是如果要让表锁定生效就必须一直保持对话。

 

P.S.  MYSQL的read lock和wirte lock


read-lock:  允许其他并发的读请求,但阻塞写请求,即可以同时读,但不允许任何写。也叫共享锁

write-lock: 不允许其他并发的读和写请求,是排他的(exclusive)。也叫独占锁

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL锁表故障注入是指攻击者通过恶意构造的SQL语句来利用MySQL的锁机制造成数据库的故障或停止服务的情况。在MySQL中,锁表是通过表级锁或行级锁来实现的。 表级锁是MySQL中锁定粒度最大的一种锁,它对当前操作的整张表进行加锁。这种锁的实现相对简单,资源消耗也较少,加锁速度较快,并且不容易出现死锁。MyISAM和InnoDB存储引擎都支持表级锁。 行级锁是MySQL中锁定粒度最小的一种锁,它只针对当前操作的行进行加锁。行级锁可以大大减少数据库操作的冲突,提高并发度。但是,行级锁的加锁开销较大,加锁速度较慢,并且容易出现死锁。 在锁表故障注入中,攻击者利用恶意构造的SQL语句,通过触发锁冲突或死锁的方式来影响数据库的正常运行。例如,攻击者可以故意向一个表中插入大量数据,导致其他事务无法获取到该表的写锁,从而导致数据库的写操作被阻塞或超时。 为了防止锁表故障注入,可以采取以下措施: 1. 使用合理的数据库设计和索引优化,减少锁的竞争。 2. 避免长时间的事务和复杂的查询语句,尽量降低锁的持有时间。 3. 合理设置事务隔离级别,根据业务需求选择合适的隔离级别。 4. 监控数据库的锁等待情况,及时发现并解决潜在的锁问题。 5. 对于不必要的表锁,可以考虑使用行级锁来替代,提高并发度和性能。 总之,MySQL锁表故障注入是一种利用MySQL的锁机制来造成数据库故障或停止服务的攻击方式。为了防止这种攻击,需要合理设计数据库架构,优化查询语句,并合理设置事务隔离级别,以减少锁冲突和死锁的发生。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Mysql数据库总结](https://blog.csdn.net/jaredray/article/details/124080045)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值