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

MySQL的join语句

MySQL的join语法 在MySQL,join语句想必大家都不陌生,今天我们围绕join语句展开,说一些可能平时不关注的知识点。...整个join语句的执行过程如下: a、从表t1拿到一条记录的字段a值 b、拿a的值去t2表查找查找匹配的行 c、找到结果,和表t1的行拼接成一行记录,作为结果的一条记录 d、重复以上三个步骤,直到...整个过程的复杂度如下: a、扫描表t1的所有100行记录 b、一行一行的用t1的字段a去t2进行查找查找的过程中会用到t2的索引,所以在t2上一共也只扫描了100行。...这里,我们简单推一下复杂度的公式: 假设驱动表的记录为M,被驱动表的值是N,因为被驱动表使用了索引,在一棵b+树上索引的查找效率近似logN,因为我们的语句时select * ,要牵扯到回表到聚集索引查询所有字段...最后介绍下,MySQL通过下面的参数来控制join buffer的大小: mysql> show variables like '%join_buffer%'; +------------------

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

MySQLMySQLSQL语句的索引分析

MySQLSQL语句的索引分析 了解过 索引 的概念以及 B+树 的概念之后,我们就来看看怎么分析一条查询语句的索引使用情况。...相信不少同学应该都使用过 EXPLAIN 来分析 SQL 语句,但是具体到 EXPLAIN 每个字段的作用,可能有不少同学还是会有点晕的。...EXPLAIN语句 接下来,我们使用 EXPLAIN 来查看这条语句。...很明显,在上面的这些类型,const 和 ref 都是非常理想的查询状态,range 则是要看情况,毕竟它不是索引命中,而是范围查找,但是在日常的业务开发,列表查询很难不使用范围查询。...不过核心的 type 字段的内容却是最常见的面试内容,当然,整个结果的其它字段也是非常有用的,具体的内容非常多,大家可以继续深入官方文档或者查找相关的资料进行学习。

8210

sql语句 模糊查找like

模糊查找:like 语法形式:字段 like ‘要查找字符’ 说明: 1、like模糊查找用于对字符类型的字段进行字符匹配查找。...2、要查找的字符,有两个特殊含义的字符:% , _: 2.1: %含义是:代表0或多个的任意字符 2.2: _含义是:代表1个任意字符 2.3: 这里的字符都是指现实可见的一个...WHERE NAME LIKE ‘张_’; — 以张开头,而且名字是两个字 SELECT * FROM student WHERE NAME LIKE ‘%张%’; — 名字里面只要有张就可以 如果要查找的字符里包含...”%”,”_”, 如果要查找的字符包含“%”或“_”,“ ’”,则只要对他们进行转义就可以: like ‘%ab\%cd%’ //这里要找的是: 包含 ab%cd 字符的字符 like ‘\_ab%’

87510

MySQLSQL语句优化路径

日常的应用开发可能需要优化SQL,提高数据访问和应用响应的效率,不同的SQL,优化的具体方案可能会有所不同,但是路径上,还是存在一些共性的。...碰巧看到杨老师的这篇文章《第45期:一条 SQL 语句优化的基本思路》,为我们优化一些MySQL数据库的SQL语句提供了可借鉴的路径,值得参考和应用。 SQL语句优化是一个既熟悉又陌生的话题。...以MySQL为例,一条SQL语句从客户端发出到数据库端返回结果一般会经历几个阶段:词法解析、语法解析、语义解析、逻辑优化、物理优化、最终执行并返回结果。...经过以上几个步骤,一般的语句基本上都能达到比较优化的结果。 虽然上面说的是MySQL数据库,但是一些理论上,其他的关系型数据库都是可以借鉴的。...当然,过程说得很简单,但是实操层面上,可能每个步骤,都会碰到一些更具体的问题,而每个问题都可能引申出更多的知识点,这就要积累了,才可以更加丰富我们的知识网。

2K10

MySQL 系列】MySQL 语句篇_DCL 语句

MySQL 访问权限控制系统的用户界面由几条 SQL 语句组成,如 CREATE USER、GRANT 和 REVOKE。 在服务器内部,MySQL 将权限信息存储在 mysql 系统库的权限表。...2、MySQL 库表的 DQL 语句详解 2.1、MySQL 服务器登录 启动 MySQL 服务后,可以通过 mysql 命令来登录 MySQL 服务器,命令如下: mysql –h hostname...如果没有该参数,就会直接登录到 MySQL 数据库,然后可以使用 USE 命令来选择数据库 -e 参数:后面可以直接加 SQL 语句。...在 MySQL ,您可以使用 CREATE USER 语句在数据库服务器创建一个新用户。...语句mysql 数据库的 user 表查询所有的用户: SELECT user, host FROM mysql.user; 2.8、用户授权 当您创建了一个新用户之后,这个新的用户可以登录

9910

MySQL 的流程控制语句

1.1 if 语句 1.1.1 语法 # 当条件表达式为 true 的时候,返回 值1,否则返回 值2 if(条件表达式, 值1, 值2); # 类似 java 的 if ··· else if...··· else 【只能使用在 begin end 之间】 if 条件语句1 then 语句1; elseif 条件语句2 then 语句2; ... else 语句n; end if; 1.1.2...表达式 when 值1 then 结果1 或者 语句1 # 如果是语句需要加分号 when 值2 then 结果2 或者 语句2 ... else 结果n 或者 语句n end [case] #...后面 case 可以省略 1.2.2 示例 # 第一种用法 # 类似 java 的 switch ··· case mysql> select id as '编号',(case sex when 1...☞ 循环控制 # 类似 java的 continue iterate 循环标签; # 类似 java 的 break leave 循环标签; ☞ 示例 # 求 1 ~ n 的和 # 创建存储过程

1.6K30

MySQL 系列】MySQL 语句篇_DML 语句

1、MySQL 的 DQL 语句 1.1、数据查询语言–DML DML(Data Manipulation Language),即数据操作语言,用于操作数据库对象中所包含的数据。...[WHERE clause]; 2、MySQL 的 DML 语句详解 2.1、DML语句:INSERT 在 MySQL ,INSERT 语句用于将一行或者多行数据插入到数据表的指定列。...2.2.3、使用 UPDATE 修饰符 在 MySQL , UPDATE 语句支持 2 个修饰符: LOW_PRIORITY: 如果你指定了 LOW_PRIORITY 修饰符,MySQL 服务器将延迟执行...2.3.6、使用 DELETE 修饰符 在 MySQL , DELETE 语句支持 3 个修饰符: LOW_PRIORITY: 如果你指定了 LOW_PRIORITY 修饰符,MySQL 服务器将延迟执行...修饰符的用法如下: DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM table_name 2.4、DML语句:REPLACE 在 MySQL ,如果你想向表插入数据

7710

MySQLMySQL基本语句

1.使用 MySQL 客户端登录: 打开终端并运行以下命令,使用你的 MySQL 用户名和密码登录到 MySQL 服务器: mysql -u your_username -p 2.连接成功后,运行以下...SQL 查询语句来获取数据库的数量: SHOW DATABASES; 3.选择数据库: 如果你有多个数据库,选择要查看的数据库: USE your_database; 查看表: 使用以下命令查看数据库的表...查看表的数据: 选择你要查看的表,然后运行 SELECT * FROM your_table; 来查看表的所有数据。...如果你只想查看表的特定列,可以指定列名,例如: SELECT column1, column2 FROM your_table; 请将 column1、column2 和 your_table 替换为实际的列名和表名...退出 MySQL 客户端: 当你完成查看后,可以使用以下命令退出 MySQL 客户端: EXIT; 或者直接按 Ctrl + D(在终端)。

10110

Sql语句Mysql的执行流程

查询缓存: 执行查询语句的时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)。    ...优化器: 按照 MySQL 认为最优的方案去执行。   执行器: 执行语句,然后从存储引擎返回数据。   ...2) 查询缓存(MySQL 8.0 版本后移除)             查询缓存主要用来缓存我们所执行的 SELECT 语句以及该语句的结果集。             ...连接建立后,执行查询语句的时候,会先查询缓存,MySQL 会先校验这个 sql 是否执行过,以 Key-Value 的形式缓存在内存,Key 是查询预计,Value 是结果集。...MySQL 查询不建议使用缓存,因为查询缓存失效在实际业务场景可能会非常频繁,假如你对一个表更新的话,这个表上的所有的查询缓存都会被清空。

4.6K10

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券