首页
学习
活动
专区
圈层
工具
发布

MySQL的SELECT …for update

最近的项目中,因为涉及到Mysql数据中乐观锁和悲观锁的使用,所以结合项目和网上的知识点对乐观锁和悲观锁的知识进行总结。...,因为在前一步我们关闭了mysql的autocommit,所以需要手动控制事务的提交,在这里就不细表了。   ...补充:MySQL select…for update的Row Lock与Table Lock   上面我们提到,使用select…for update会把数据给锁住,不过我们需要注意一些锁的级别,MySQL...InnoDB默认Row-Level Lock,所以只有「明确」地指定主键,MySQL 才会执行Row lock (只锁住被选取的数据) ,否则MySQL 将会执行Table Lock (将整个数据表单给锁住...select * from person where id>=2 for UPDATE   以上就是关于数据库主键对MySQL锁级别的影响实例,需要注意的是,除了主键外,使用索引也会影响数据库的锁定级别

4.7K30

【mysql】基本的select语句

去除重复行 查询员工表中一共有哪些部门id SELECT DISTINCT department_id FROM employees; [在这里插入图片描述] #错误的:没有去重的情况 SELECT...一个空字符串的长度是 0,而一个空值的长度是空。而且,在 MySQL 里面,空值是占用空间的。4....syntax to use near 'order' at line 1 正确的 mysql> SELECT * FROM `ORDER`; +----------+------------+ | order_id...查询常数 SELECT 查询还可以对常数进行查询。就是在 SELECT 查询结果中增加一列固定的常数列。这列的取值是我们指定的,而不是从数据表中动态取出的。...] 练习:查询last_name为'King'的员工信息 SELECT * FROM EMPLOYEES WHERE LAST_NAME = 'King'; [在这里插入图片描述] 注意:mysql

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

    mysql(基本的SELECT语句)

    在学习SELECT之前我们先来了解下关于它的基本知识点:   SQL语言的规则与规范 SQL 可以写在一行或者多行。...(' ')表示列的别名,尽量使用双引号(" "),而且不建议省略as  单行注释:#注释文字(MySQL特有的方式) 单行注释:-- 注释文字(--后面必须包含一个空格。)...空值参与运算 所有运算符或列值遇到null值,运算的结果都为null SELECT NULL+1,NULL-1,NULL*1,NULL>1,NULL<1,NULL=1 FROM DUAL 在 MySQL...一个空字符串的长度是 0,而一个空值的长度是空。而且,在 MySQL 里面,空值是占用空间的。  着重号 我们需要保证表中的字段、表名等没有和保留字、数据库系统或常用方法冲突。...(键盘上1数字的旁边那玩意) 补充: SELECT 查询还可以对常数进行查询。对的,就是在 SELECT 查询结果中增加一列固定的常数列。这列的取值是我们指定的,而不是从数据表中动态取出的。

    2.4K30

    mysql中select子查(select中的select子查询)询探索

    ------+------+ | 4 | 运营 | 杭州 | +--------+-------+------+ 1 row in set (0.08 sec) select 中的子查询 mysql...),也就是select dname from dept d where e.deptno = d.deptno但是这部分是不能单独执行的,所以猜测mysql对这部分做了处理,处理成类似这种select...= 3; Subquery returns more than 1 row 子查询中的limit mysql> select d.dname,(select e.ename from emp e where...子查询可能的使用场景 带统计的查询 查询部门名称,地点,和部门人数 mysql> select dname,loc,(select count(empno) from emp e where e.deptno...,主查询只需要一行,例如查询部门名称,所在地,和部门中id最大的一个人的名称 mysql> select d.dname,(select e.ename from emp e where e.deptno

    2K00

    select语句的执行流程(MySql)

    学习了极客时间MySql课程,做个总结 以一条select语句为例:select * from T where ID=4 ,梳理下执行的流程 一条sql语句在执行过程中需要经过连接器、分析器、优化器、...假设此时修改了你的权限,那么也是不会影响你本次的连接的,只有在下一次创建连接,查询权限的时候才会生效。...查询缓存 在经过连接器之后,会执行第二步查询缓存,在MySql拿到查询后,会先到查询缓存查看是否执行过这条语句,之前执行的结果会以key-value对的形式存在,如果不在查询缓存中,会继续执行后面的极端...在MySql8.0之后去掉了查询缓存的功能。...分析器 分析器会先做“词法分析”,识别出sql里的字符串分别是什么,读出“select”关键字对出这是一条查询语句,把字符串T识别成“表T” “语法分析”,根据词法分析的结果,判断该条sql是否满足MySql

    70110

    Mysql,再见吧,select * !

    作者:AIOps 应用程序慢如牛,原因多多,可能是网络的原因、可能是系统架构的原因,还有可能是数据库的原因。 那么如何提高数据库SQL语句执行速度呢?...有人会说性能调优是数据库管理员(DBA)的事,然而性能调优跟程序员们也有莫大的关系。 程序中嵌入的一行行的SQL语句,如果使用了一些优化小技巧,定能达到事半功倍的效果。...然而,为了达到更好的性能以及更好的数据控制,你可以将他们变成多个小查询。...技巧7 尽量避免使用 “SELECT *” 如果不查询表中所有的列,尽量避免使用 SELECT *,因为它会进行全表扫描,不能有效利用索引,增大了数据库服务器的负担,以及它与应用程序客户端之间的网络IO...技巧10 ORDER BY 的列尽量被索引 ORDER BY的列如果被索引,性能也会更好。 技巧11 使用 LIMIT 实现分页逻辑 不仅提高了性能,同时减少了不必要的数据库和应用间的网络传输。

    1.6K10

    MySQL的insert into select 引发锁表

    MySQL一般我们在生产上备份数据通常会用到 这两种方法: INSERT INTO SELECT CREATE TABLE AS SELECT 注:本文仅针对MySQL innodb引擎,事务是可重复读...…中必须包括主键 在执行语句的时候,MySQL是逐行加锁的(扫描一个锁一个),直至锁住所有符合条件的数据,执行完毕才释放锁。...CREATE TABLE AS SELECT create table as select 会创建一个不存在的表,也可以用来复制一个表。...因此从MySQL5.5版本开始引入了MDL锁,来保护表的元数据信息,用于解决或者保证DDL操作与DML操作之间的一致性。 注意: 新表不会自动创建创建和原表相同的索引。...业务少的情况(深夜什么的)下,可以使用 create table as select 。 ---- 知识又增加了。 ? --end--

    2.4K10

    【重学MySQL】十三、基本的 select 语句

    【重学MySQL】十三、基本的 select 语句 基本的SELECT语句是SQL(Structured Query Language,结构化查询语言)中最常用的语句之一,用于从数据库表中检索数据...然而,值得注意的是,虽然DUAL在Oracle数据库中是一个常见的概念,但在MySQL中,它并不是严格必需的,因为MySQL允许你执行没有FROM子句的SELECT语句。...这意味着,在MySQL中,你可以直接写出一个只包含SELECT和可能的一些函数的查询,而不需要显式地引用DUAL表。...在这种情况下,MySQL仍然能够处理这样的查询,因为MySQL会忽略这个DUAL的引用,并直接执行SELECT语句中的计算或函数。...总的来说,DUAL在MySQL中是一个可选的概念,主要用于与那些期望在所有数据库系统中都有DUAL表的概念的代码兼容。但在实际使用中,你通常可以省略它,直接在MySQL中执行你的SELECT语句。

    1.4K10

    MySQL的insert into select 引发锁表

    MySQL一般我们在生产上备份数据通常会用到 这两种方法: INSERT INTO SELECT CREATE TABLE AS SELECT 注:本文仅针对MySQL innodb引擎,事务是可重复读...…中必须包括主键 在执行语句的时候,MySQL是逐行加锁的(扫描一个锁一个),直至锁住所有符合条件的数据,执行完毕才释放锁。...CREATE TABLE AS SELECT create table as select 会创建一个不存在的表,也可以用来复制一个表。...因此从MySQL5.5版本开始引入了MDL锁,来保护表的元数据信息,用于解决或者保证DDL操作与DML操作之间的一致性。 注意: 新表不会自动创建创建和原表相同的索引。...业务少的情况(深夜什么的)下,可以使用 create table as select 。 ---- 知识又增加了。 ?

    7.3K31

    MySQL之优化SELECT语句

    MySQL之优化SELECT语句 摘要: 本文主题为MySQL优化SELECT语句,涵盖了数据库性能提升概述,WHERE子句优化,范围优化和哈希联接优化。...优化SELECT语句是提高数据库性能的关键一环。本文将探讨几个关键的优化技术,包括WHERE子句优化、范围优化和哈希联接优化。...查询优化之前的查询 SELECT * FROM employees WHERE age >= 30 ORDER BY hire_date; 查询优化之后的查询 SELECT id, name, position...确保WHERE条件上的列有合适的数据类型: 查询优化前:使用字符串进行比较 SELECT * FROM employees WHERE age = '30'; 查询优化后:使用正确的数据类型 SELECT...2.覆盖索引(Covering Index): 当MySQL发现查询的SELECT列都在索引中已经包含时,它可以使用覆盖索引,避免访问表的数据行,从而提高查询效率。

    1K10

    MySQL对CREATE TABLE IF NOT EXISTS SELECT的处理

    1.MySQL对CREATE TABLE IF NOT EXISTS SELECT的处理 MySQL支持创建持数据表时判断是否存在,存在则不创建,不存在则创建,相应语句如下: --格式 CREATE...官方对CREATE TABLE IF NOT EXISTS SELECT给出的解释是: CREATE TABLE IF NOT EXIST… SELECT的行为,先判断表是否存在, 如果存在...当数据表存在的时候,使用insert into select将select的结果插入到数据表中,当select的结果集的列数与数据表的列数不相匹配时,又分为两种情况: 第一种:select的结果列数m小于原数据表的列数...n,那么将select的结果插入到数据表的最有表,左边n-m列以默认值填充。...官方英文描述如下: For CREATE TABLE … SELECT, if IF NOT EXISTS is given and the table already exists, MySQL

    4.1K30
    领券