首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

select......for update还是行?

select查询语句是不会加锁的,但是select .......for update除了有查询的作用外,还会加锁呢,而且它是悲观。 那么它加的是行还是,这就要看是不是用了索引/主键。...没用索引/主键的话就是,否则就是是行。...0代手动提交,1代自动提交。 实例1: 使用主键id为条件去查询,然后开启另一个事务去更新数据,更新被阻塞,加锁了,锁定要查询的id为1的行数据。...实例4: 使用普通的字段code去操作 另一个事务我去更新另外一条数据,如果我更新成功了,就是行,失败了就是。...结果: 如果查询条件用了索引/主键,那么select ..... for update就会进行行。 如果是普通字段(没有索引/主键),那么select ..... for update就会进行

1.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql 中select for update 的范围备注

    mysql范围测试 1.主键明确时,行级:   解释:指定主键并且数据存在时,仅锁定指定的行,其它行可以进行操作   实例:指定了锁定id=1的行且数据存在①,在更新1时lock wait超时②...,但是更新id不为1的项目时可以直接更新③,释放后④,可以任意更新⑤ ?...2.主键不明确时,:   解释:指定主键不明确或者数据不存在时,整锁定   指定主键不明确包括使用in、not in、等  ?...3.使用非主键限定时,:   解释:如果where条件中不存在主键限定而采用非主键筛选,全锁定 ? 所以要实现行级来实现高并发场景时,必须明确指定主键,否则整个锁定,影响其它线程操作。...注意:测试时请开两个窗口测试,并且 for update语句要在 begin后 commit前

    3K20

    小白学习MySQL - 查询

    我们知道,Oracle中除了使用select ... for update,其他查询语句不会出现,即没有读,读一致性通过多版本解决的,可以保证在不加锁的情况下读到正确的数据。...问题来了,Oracle中执行的insert into select很正常,不会出现,难道相同的语句用在了MySQL,就会锁住整张?...,有五个record lock,虽然我只从test_1读取一行数据,但实际上对test_1的所有记录都加了,而且显式对test_1加了一个IS的意向,因此这种操作,确实影响了select的并发执行...解决方案2:更改隔离级别 在创建索引前,之所以会出现的情况,和隔离级别是相关的,首先看下数据库的隔离级别。...test_2上是没有任何,因此不会出现RR锁定test_2的情况, mysql> show engine innodb status \G; ... ------------ TRANSACTIONS

    2.3K30

    select for update加了行还是

    最近在开发需求的时候,用到了select......for update。在代码评审的时候,一位同事说 ,唯一索引+一个非索引字段,是否可能呢?...如下图: 事务二的更新语句为什么阻塞呢? 因为事务一的select......for update已经加了了嘛。那加的是行还是呢?...为什么不是一个的X呢? 这是因为: 若age列上没有索引,MySQL走聚簇(主键)索引进行全扫描过滤。每条记录都会加上X。...因此,在RR隔离级别下,如果select......for update的查询条件是普通索引的话,命中查询记录的话,除了会加两把X(行),IX,不影响插入),还会加Gap (间隙影响插入...3.4 RR隔离级别 + 无索引 在RR隔离级别下,如果select......for update的查询条件是无索引的话,嘛?

    52210

    技术分享 | MySQL中查询 ?

    ---- 我们知道,Oracle 中除了使用 select ... for update ,其他查询语句不会出现,即没有读,读一致性通过多版本解决的,可以保证在不加锁的情况下,读到同一时间的数据。...问题来了,Oracle 中执行的 insert into select 很正常,不会出现,难道相同的语句用在了 MySQL ,就会锁住整张?...解决方案2:更改隔离级别 在创建索引前,之所以会出现的情况,和隔离级别是相关的,首先看下数据库的隔离级别。...> begin; Query OK, 0 rows affected (0.00 sec) mysql> update test_1 set name='test_6' where id=5; Query...test_2 上是没有任何,因此不会出现 RR 锁定 test_2 的情况, mysql> show engine innodb status \G; ... ------------ TRANSACTIONS

    5.5K10

    select...for update 了?

    select...for updateMySQL中,是一种悲观的用法,一般情况下,锁住一行数据,但如果没有使用正确的话,也会把整张锁住。...目前MySQL中使用比较多的有:、行和间隙。 我们这个业务场景,非常时候使用行。...在MySQL中是通过select...for update语句来实现的行的功能。 但如果你在实际工作中使用不正确,也容易把整张锁住,严重影响性能。...总结 最后给大家总结一下select...for update加锁的情况: 主键字段:加行。 唯一索引字段:加行。 普通索引字段:加行。 主键范围:加多个行。 普通字段:加。...如果事务1加了行,一直没有释放,事务2操作相同行的数据时,一直等待直到超时。 如果事务1加了,一直没有释放,事务2不管操作的是哪一行数据,都会一直等待直到超时。

    32530

    MySQLupdate操作

    MySQLupdate操作 一、介绍 记录一下MySQL后进行update的操作,这可以一口气同时改动到多张的数据,可以取到关联的数据进行更新。...作用还是比较大的,如下 二、使用 1)建 分别有以下四张,分别为 学生 班级 学生评分 班级评分 CREATE TABLE `tb_student` ( `id`...; 模型如下图 2)连更新 如果班级里张三比较调皮,在班级座位后面睡觉被校长发现了,要把这位学生和所在班级的评分,各扣10分 如果是以前,我可能是写两条update语句的sql,现在的话,可以关联起来这样写...`name` = '张三'; ---- 那么此时,我们只需要做一点小小的改动,就可以把上述sql改为连update的了。...将select 字段... from 改为update 在where条件前写上自己,需要更新的字段 简单两步,改动结果后的sql如下 update tb_student t0 join tb_student_grade

    4.3K30

    MySQL

    为了解决这个问题,MySQL引入了机制,其中最常见的是行。 行MySQL中最细粒度的,它锁定了中的一行记录,允许其他事务访问中的其他行。...行适用于高并发的情况,因为它允许多个事务同时访问的不同行,从而提高了数据库的并发性能。 MySQL中粗粒度的,它锁定了整个,阻止其他事务访问中的任何行。...适用于需要对整个进行操作的情况,但它会降低数据库的并发性能,因为只有一个事务可以访问。 行的使用 行可以通过在SQL语句中使用FOR UPDATE或FOR SHARE子句来实现。...不同的隔离级别影响行的行为,需要根据应用程序的需求进行选择。 的使用 是通过使用LOCK TABLES语句来实现的。...在解锁之前,其他事务无法访问。 需要注意的是,阻止其他事务访问相同的,因此在高并发环境中使用可能导致性能问题。

    32740

    MySQLMySQL(二)与行测试

    MySQL(二)与行测试 上篇文章我们简单的了解了一大堆锁相关的概念,然后只是简单的演示了一下 InnoDB 和 MyISAM 之间 与 行 的差别。...但是 UNLOCK 不能针对某一张,而是使用 UNLOCK TABLES; MySQL 自动进行解锁释放。 全局 除了单独一张之外,我们还可以一个库中所有的。...-- 排它及意向排它 mysql> begin; mysql> UPDATE test_user2 SET name = 'fff' WHERE id = 1212121; -- 情况 mysql...,除了 DDL 时会加的 元数据 之外(下回我们讲它),还有一种情况就是如果不走索引,也让行变成。...,在这种情况下,整个更新语句扫全,同时变成 ,因此,下面针对某条单行数据的更新语句就会阻塞。

    18310

    mysql 详解

    为了给高并发情况下的MySQL进行更好的优化,有必要了解一下mysql查询更新时的机制。 一、概述 MySQL有三种的级别:页级、级、行级。...2、MySQL模式 MySQL有两种模式:共享读(Table Read Lock)和独占写(Table Write Lock)。...MyISAM在执行查询语句(SELECT)前,自动给涉及的所有加读,在执行更新操作(UPDATE、DELETE、INSERT等)前,自动给涉及的加写。...对于1中的客户端1,此时没有加锁,当然也没有加写了,那么此时客户端1对加了一个读。 对于1中的客户端2,此时因为有一个读,所以把UPDATE请求放到写锁定队列中。...当您调用LOCK TABLES时,InnoDB内部地取其自己的锁定,MySQL取其自己的锁定。

    3.4K10

    select for update是行还是,还真得看情况

    分析思路:一,如果更新数据被阻塞,则说明加锁成功;二,如果更新其他数据成功,则说明是行,如果更新其他数据失败则说明是。三,部分场景测试插入操作;后续所有操作基本雷同。...结论:当查询条件有索引且查询条件为范围时,select for update采用间隙或临键,对指定范围内的数据进行加锁。当然,当查询条件无索引时,与场景1.4一致,为。...结论:当查询条件有索引且查询条件为范围时,select for update采用间隙或临键,对指定范围内的数据进行加锁。...原因:会出现上述情况的原因是,本来如果条件上没有索引,MySQL走聚簇(主键)索引进行全扫描过滤,每条记录都会添加上X。但为了效率,MySQL会对扫描过程中不满足条件的记录进行解锁操作。...版本 主键 唯一索引 普通索引 无索引 范围查询 MySQL 5.7.x - RR X:行 X,行 X,GAP:行,间隙,条件范围内阻塞 指定范围加锁,insert阻塞 MySQL 8.0

    1.3K31

    MySQL中的、行

    页面:开销和加锁时间界于和行之间;会出现死锁;锁定粒度界于和行之间,并发度一般 MySQL模式(MyISAM) MySQL有两种模式:共享(Table Read Lock...MySQL模式     MySQL的有两种模式:共享读(Table Read Lock)和独占写(Table Write Lock)。...如何加     MyISAM在执行查询语句(SELECT)前,自动给涉及的所有加读,在执行更新操作(UPDATE、DELETE、INSERT等)前,自动给涉及的加写,这个过程并不需要用户干预...答案是写进程先获得。不仅如此,即使读进程先请求先到等待队列,写请求后到,写插到读请求之前!这是因为MySQL认为写请求一般比读请求重要。...对于UPDATE、DELETE和INSERT语句,InnoDB自动给涉及及数据集加排他(X);对于普通SELECT语句,InnoDB自动给涉及数据集加排他(X);对于普通SELECT语句,InnoDB

    4.8K10

    MySQL中的、行

    页面:开销和加锁时间界于和行之间;会出现死锁;锁定粒度界于和行之间,并发度一般 MySQL模式(MyISAM) MySQL有两种模式:共享(Table Read Lock...MySQL模式 MySQL的有两种模式:共享读(Table Read Lock)和独占写(Table Write Lock)。...如何加 MyISAM在执行查询语句(SELECT)前,自动给涉及的所有加读,在执行更新操作(UPDATE、DELETE、INSERT等)前,自动给涉及的加写,这个过程并不需要用户干预,因此用户一般不需要直接用...答案是写进程先获得。不仅如此,即使读进程先请求先到等待队列,写请求后到,写插到读请求之前!这是因为MySQL认为写请求一般比读请求重要。...对于UPDATE、DELETE和INSERT语句,InnoDB自动给涉及及数据集加排他(X);对于普通SELECT语句,InnoDB自动给涉及数据集加排他(X);对于普通SELECT语句,InnoDB

    5.1K20
    领券