MySQL索引B+树、执行计划explain、索引覆盖最左匹配、慢查询问题 B树与B+树的区别及MySQL为何选择B+树 在数据库中,为了提高查询效率和数据的持久化存储,在设计索引时通常会采用B树或B+...B树和B+树的基本概念 B树是一种平衡多路查找树,相比于二叉查找树,它允许一个节点存在多个子节点,因此可以减少I/O操作的次数,提高数据的访问效率。...const:通过索引一次就找到了,const与主键或唯一索引一起使用时,最多只会返回一条记录。 eq_ref:使用唯一索引或主键进行关联,只返回匹配到的一行记录。...all:Full Table Scan(Full Table Scan),这是最坏的情况,扫描全表查找匹配的行。 possible_keys字段:该字段显示可能用于此查询的键列表。...对于选择查询,可能的键是指可以用来查找所需记录的索引列表。对于更新查询,可能的键列表是可以用于唯一查找被更新记录的索引列表。 key字段:该字段显示MySQL实际决定使用哪个索引来优化此查询。
MySQL 支持大型数据库,支持 5000 万条记录的数据仓库,32 位系统表文件最大可支持 4GB,64 位系统支持最大的表文件为8TB。...#值:行的具体信息,每个值必须与该列的数据类型相同 #键:键的值在当前列中具有唯一性 MySQL数据库的安装 #第一步:下载 下载地址:https://dev.mysql.com/downloads/...依赖于M和D的值 #日期和时间类型 每个时间类型有一个有效范围和一个“零”值,当指定不合法的MySQL不能表示的值时使用“零”值。...*查询语句中可以使用多个表,表之间使用逗号分隔,并使用where语句是定查询条件 *select命令可以读取一条或多条记录 *可以使用(*)来代替其他字段,select语句会返回表的所有字段数据 *可以使用...可以使用 and or 来包含多个条件 where语句的操作符列表: 操作符 描述 例子 = 等号,检测两个值是否相等,如果相等返回true (A=B)返回true ,!
SELECT D FROM TABLE WHERE C LEAST(A,B) GREATEST 最大值运算符 在多个值中放回最大值 SELECT D FROM TABLE WHERE C GREATEST...MySQL中使用REGEXP关键字指定正则表达式的字符匹配模式。下表列出了REGEXP操作符中常用字符匹配 列表。...*' # 5.匹配指定字符串 正则表达式可以匹配指定字符串,只要这个字符串在查询文本中即可,如要匹配多个字符串,多个字符串之间使用分隔符‘|’隔开。...函数 MySQL的内置函数及分类 MySQL提供的内置函数从 实现的功能角度 可以分为数值函数、字符串函数、日期和时间函数、流程控制 函数、加密与解密函数、获取MySQL信息函数、聚合函数等。...日期和时间函数 获取日期、时间 日期与时间戳的转换 获取月份、星期、星期数、天数等函数 日期的操作函数 EXTRACT(type FROM date)函数中type的取值与含义: 时间和秒钟转换的函数
MySQL数据库完整知识点梳理 基础查询部分知识点 语法 查询表中的单个字段 查询表中的多个字段 查询表中的所有字段 查询常量值 查询表达式 查询函数 起别名 去重 +号的作用 concat函数---...返回大于等于该参数的最小整数 3. floor 向下取整,返回小于等于该参数的最大整数 4.truncate 截断----->只保留小数点后几位,不进行四舍五入操作 5.mod 取余 日期函数 1.now...,其他的字段是不能查询的,查了报错 虽然不能单独查询非分组字段,但是可以把聚合函数查询用在非分组字段上 分组查询一般是和聚合查询结合使用,针对每个分组去做聚合(最大值,最小值,计数) 连接查询---多表查询...classses 班级,max(mysql) mysql最高成绩 FROM `class` GROUP BY classses; 分组查询一般是和聚合查询结合使用,针对每个分组去做聚合(最大值,最小值...: a>all(10,20,30)—>a大于all括号里面所有值才成立,即大于最大值 例1: 查找工资在3000-3800之间的员工中,对应的每个员工的ID SELECT workerID FROM
日期和时间类型 日期与时间类型是为了方便在数据库中存储日期和时间而设计的,数据库有多种表示日期和时间的数据类型。...列表中的每个值独有一个顺序排列的编号,MySQL中存入的是这个编号,而不是列表中的值。默认编号从1开始!...其基本形式与ENUM类型一样。SET类型的值可以取列表中的一个元素或者多个元素的组合。取多个元素时,不同元素之间用逗号隔开。SET类型的值最多只能是由64个元素构成的组合。...; 参数tablename表示表名, 参数fieldn表示表中的字段名字,通过关键字LIKE来判断字段field的值是否与value字符串匹配,如果相匹配,则满足查询条件,该记录就会被查询出来;...,并返回记录的自增长id。
① 内连接 内连接是最常用的联接类型,它返回两个表中匹配的记录。...,它返回右表中的所有记录以及左表中匹配的记录。...子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询 单行子查询:返回一行记录的子查询 多行子查询:返回多行记录的子查询 -- 错误范例 select name from employees...一个表只能有一个主键索引,主键字段的值必须唯一且不能为空。 唯一索引(UNIQUE): 唯一索引确保索引列中的每个值都是唯一的,可以有多个唯一索引。...的四舍五入的值,保留 y 位小数 8.3 日期函数 函数 功能 CURDATE() 返回当前日期 CURTIME() 返回当前时间 NOW() 返回当前日期和时间 YEAR(date) 获取指定 date
因为只匹配一行数据,所以很快。如将主键置于where列表中,MySQL就能将该查询转换为一个常量。 eq_ref 唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配。...常见于主键或唯一索引扫描 ref 非唯一性索引扫描,返回匹配某个单独值的所有行,本质上也是一种索引访问,它返回所有匹配某个单独值的行,然而,它可能会找到多个符合条件的行,所以他应该属于查找和扫描的混合体...也就是索引列的cardinality的值与表中数据的总条数差距越大,即使查询的时候使用了该索引作为查询条件,实际存储引擎实际查询的时候使用的概率就越小。...中包含(str)的结果,返回结果为null或记录 假如字符串str在由N个子链组成的字符串列表strlist 中,则返回值的范围在 1 到 N 之间。...外键创建失败的几种原因 外键的字段与关联的字段的类型不匹配(包括编码格式的不匹配) 外键的名字是一个已经存在的键值,要保证名字的唯一 mysql引擎引起的外键创建不能保存或者不能发挥作用的情况,mysql
日期的操作函数 时间和秒钟转换的函数 计算日期和时间的函数 日期的格式化与解析 流程控制函数 加密与解密函数 MySQL信息函数 其他函数 聚合函数(多行函数) AVG和SUM函数 MIN和MAX函数...,e3…) 返回列表中的最小值 GREATEST(e1,e2,e3…) 返回列表中的最大值 MOD(x,y) 返回X除以Y后的余数 RAND() 返回0~1的随机值 RAND(x) 返回0~1的随机值,...返回date所在月份的最后一天的日期 MAKEDATE(year,n) 针对给定年份与所在年份中的天数返回一个日期 MAKETIME(hour,minute,second) 将给定的小时、分钟和秒组合成时间并返回...如果在子查询中不存在满足条件的行: 条件返回 FALSE 继续在子查询中查找 如果在子查询中存在满足条件的行: 不在子查询中继续查找 条件返回 TRUE NOT EXISTS关键字表示如果不存在某种条件...这句的作用是使用游标名这个游标来读取当前行,并且将数据保存到变量中(读取游标,并赋值给变量),游标指针指到下一行。如果游标读取的数据行有多个列名,则在 INTO 关键字后面赋值给多个变量名即可。
RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。 示例: 以一个共同的字段,求两张表当中符合条件的并集。...= NULL 在列中查找 NULL 值 。 在 MySQL 中,NULL 值与任何其它值的比较(即使是 NULL)永远返回 NULL,即 NULL = NULL 返回 NULL 。...创建索引时,你需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。 实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。...函数,但是每个字符串之间要加上 x,x 可以是分隔符 合并多个字符串,并添加分隔符: SELECT CONCAT_WS("-", "SQL", "Tutorial", "is", "fun!")...返回列表中的最大值 返回以下数字列表中的最大值: SELECT GREATEST(3, 12, 34, 8, 25); -- 34 返回以下字符串列表中的最大值: SELECT GREATEST("Google
DISTINCT, ALL 选项 distinct 去除重复记录 默认为 all, 全部记录 UNION 将多个select查询的结果组合成一个结果集合。...默认 DISTINCT 方式,即所有返回的行都是唯一的 建议,对每个SELECT查询加上小括号包裹。 ORDER BY 排序时,需加上 LIMIT 进行结合。...需要各select查询的字段数量一样。 每个select查询的字段列表(数量、类型)应一致,因为结果中的字段名以第一条select语句为准。 子查询 - 子查询需用括号包裹。...set @var = value; 也可以使用select into语句为变量初始化并赋值。...这样要求select语句只能返回一行,但是可以是多个字段,就意味着同时为多个变量进行赋值,变量的数量需要与查询的列数一致。 还可以把赋值语句看作一个表达式,通过select执行完成。
MEDIUMTEXT:最大长度16,777,215的非二进制字符串 LONGTEXT:最大长度4,294,967,295的非二进制字符串 ENUM:枚举类型,可从列表中选择一个值 SET:集合类型,可从列表中选择多个值...在使用复合索引进行查询时,MySQL会首先匹配索引的最左边的列(第一个列),然后依次匹配后续的列。...UNION操作符用于合并两个或多个SELECT语句的结果集,并且会默认去除重复的行,只返回唯一的行。...ORDER BY SumOrderAmount DESC 9、LIMIT 或 TOP LIMIT(MySQL)或 TOP(SQL Server)子句限制了查询返回的行数,并选择性地跳过指定的行数。...2.查询缓存,在这里,mysql拿到查询语句,会先去缓存里找,如果之前执行过相同的语句,那么这里就可以直接从缓存中取出结果返回,如果不在缓存中就继续向下执行。
不同的编码,所占用的空间不同。 char,最多255个字符,与编码无关。 varchar,最多65535字符,与编码有关。 一条有效记录最大不能超过65535个字节。...默认 DISTINCT 方式,即所有返回的行都是唯一的 建议,对每个SELECT查询加上小括号包裹。 ORDER BY 排序时,需加上 LIMIT 进行结合。 需要各select查询的字段数量一样。...每个select查询的字段列表(数量、类型)应一致,因为结果中的字段名以第一条select语句为准。 /* 子查询 */ ------------------ - 子查询需用括号包裹。...-- from型 from后要求是一个表,必须给子查询结果取个别名。 - 简化每个查询内的条件。 - from型需将结果生成一个临时表格,可用以原表的锁定的释放。 - 子查询返回一个表,表型子查询。...这样要求select语句只能返回一行,但是可以是多个字段,就意味着同时为多个变量进行赋值,变量的数量需要与查询的列数一致。 还可以把赋值语句看作一个表达式,通过select执行完成。
领取专属 10元无门槛券
手把手带您无忧上云