(在上一篇文章中,我们知道MySQL先在索引上按值进行查找,然后返回索引值对应的数据行,一旦对索引列进行运算,则将无法正确的找到对应的数据行,从而改为全表逐行扫描查询对比) 二、前缀索引和索引选择性 有时候将内容很长的列作为索引列...索引的选择性是指,不重复的索引值(也称为基数)和表数据的记录总数T的比值,范围从1/T到1之间。索引的选择性越高,则查询效率越高,因为选择性高的索引可以让MySQL在查找时过滤掉更多的行。...然而性能不只是依赖于所有索引列的选择性,也和查询条件的具体值有关,也就是和值的分布有关(需要根据那些运行频率最高的查询来调整索引列的顺序,让这种情况下的索引列的选择性最高)。...覆盖索引必须要存储索引列,而哈希索引、空间索引和全文索引等都不存储索引列的值,所以MySQL只能使用B-Tree所以来做覆盖索引,另外不同的存储引擎实现覆盖索引的方式也不同,而且不是所有的引擎都支持覆盖索引...然而唯一限制和主键限制都是通过索引使用,因此,上面的写法实际上在相同的列上创建了三个重复的索引。通常并没有理由要这样做,除非是在同一列上创建不同类型的索引来满足不同的查询需求。
2、使用null值 null就是没有值或者缺值;允许null值的列也允许在插入行时不给出该列的值,不允许null值的列不接受该列没有值的行(插入或更新行时,该列必须有值); 每个表列或者是null列,或者是...MySQL相比于其他DBMS的区别在于,它具有多种引擎;因为各个引擎有不同的功能和特性,为不同的任务选择正确的引擎能获得良好的功能和灵活性。...PS:传递给match()的值必须与fulltext()定义中的相同;如果指定多个列,则必须列出它们(次序正确);除非使用binary方式,否则全文本搜索不区分大小写(上面的例子没有使用该方式)。 ...like子句具有和全文本搜索相同的功能,但区别在于:全文本搜索的特点是对结果进行排序,具有较高等级的行先返回(如果排序多个搜索项,则包含多数匹配词的行将具有更高的优先级)。...检索过程: ①进行一个基本的全文本搜索,找出与搜索条件匹配的所有行; ②MySQL检查这些匹配行并选择所有有用的词(将会简要的解释MySQL如何断定什么有用什么无用); ③MySQL再次进行全文本搜索,
B-Tree通常意味着所有值都是按顺序存储的,并且每个叶子页到根的距离相同。存储引擎已不同的方式来使用B-Tree索引,性能也各不相同。...哈希索引将所有的哈希码存储在索引中,同时在哈希表中保存指向每个数据行的指针。 1.3、全文索引 全文索引是一种特殊类型的索引,它查找的是文本中的关键词,而不是直接比较索引中 的值。...前缀索引能大大节约索引空间,从而提高索引效率,但这样也会降低索引的选择性(索引选择性——不重复的索引值和数据表记录总数的比值); 索引前缀长度的选择——计算法。...例如:key(col1, col2, col3); MySQL5.0之后的版本引入了“索引合并”的策略,一定程度上可以使用表上的多个单列索引来定位表中的行; 索引合并策略有时候是一种优化后的结果,但实际上更说明表上的索引建得很糟糕...对于MyISAM表,这三类碎片都可能发生,但InnoDB不会出现短小的行碎片,InnoDB会移动短小的行,并重写到一个片段中。
a.id=b.id EXPLAIN列的解释: table:显示这一行的数据是关于哪张表的。...如果不想返回表中的全部行,并且连接类型ALL或index,这就会发生,或者是查询有问题不同连接类型的解释(按照效率高低的顺序排序)。 system: 表只有一行:system表。...因为只有一行,这个值实际就是常数,因为MySQL先读这个值然后把它当做常数来对待。...2)区分度最高的放在联合索引的最左侧(区分度=列中不同值的数量/列的总行数) 3)使用最频繁的列放到联合索引的左侧(这样可以比较少的建立一些索引) (2)表关联查询 1)类型和大小要相同...VARCHAR(10)和 CHAR(10)大小相同,但 VARCHAR(10)与 CHAR(15)不相同。 2)字符串列之间比较,两列应使用相同的字符集。
表中R1~R5的(ID,k)值分别为(100,1)、(200,2)、(300,3)、(500,5)、(600,6),每一个索引在InnoDB里面对应一棵B+树,两棵树的简意示意图如下: 1.2 主键索引和普通索引的区别...a.id=b.id EXPLAIN列的解释: table:显示这一行的数据是关于哪张表的。...如果不想返回表中的全部行,并且连接类型ALL或index,这就会发生,或者是查询有问题不同连接类型的解释(按照效率高低的顺序排序)。 system: 表只有一行:system表。...(区分度=列中不同值的数量/列的总行数) 3)使用最频繁的列放到联合索引的左侧(这样可以比较少的建立一些索引) 2、表关联查询 1)类型和大小要相同,可以使用索引。...VARCHAR(10)和 CHAR(10)大小相同,但 VARCHAR(10)与 CHAR(15)不相同。 2)字符串列之间比较,两列应使用相同的字符集。
一、SELECT语句 使用select查询表数据,必须至少给出两条信息——想选择什么,以及从什么地方选择。 #1.查询单个列: select id from stu; ?...未排序数据 如果没有明确排序查询结果,可能会发现显示输出的数据顺序与原表不同,返回的数据的顺序没有特殊意义,可能是数据被添加到表中的顺序,也可能不是,只要返回相同数目的行就是正常的。...#2.查询多个列:查询学生表的id,name两列的值 select id,name from stu; ? 在select关键字后给出多个列名,列名之间以逗号分隔,最后一个列名后不加逗号。...#3.查询所有列:查询学生表所有列的值 select * from stu; ? 使用*通配符 一般,除非确实需要表中的每个列,否则最好别使用*通配符。...行数不够时 LIMIT中指定要检索的行数为检索的最大行数,如果没有足够的行(例如,给出LIMIT 10, 5,但只有13行),MySQL将只返回它能返回的那么多行。 以上 That's all.
因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推 迟到运行时;它必须在编译时进行选择。然而,如果在编译时建立访问计划,变量的值还是未知的,因而无法作为索引选择的输入项。...2)、id不同 如果我们的 SQL 中存在子查询,那么 id的序号会递增,id值越大优先级越高,越先被执行 。当三个表依次嵌套,发现最里层的子查询 id最大,最先执行。 这里也有相同id。...即相同id划分为一组,同组的从上往下顺序执行,不同组 id值越大,优先级越高,越先执行。...在这种情况下,MySQL使用t1.id的值扫描t1并查找t2中的行。...如果MySQL在t2中发现一个匹配的行,它知道t2.id绝不会为NULL,并且不再扫描t2内有相同的id值的行。
空值参与运算 所有运算符或列值遇到null值,运算的结果都为null SELECT NULL+1,NULL-1,NULL*1,NULL>1,NULL<1,NULL=1 FROM DUAL 在 MySQL...一个空字符串的长度是 0,而一个空值的长度是空。而且,在 MySQL 里面,空值是占用空间的。 着重号 我们需要保证表中的字段、表名等没有和保留字、数据库系统或常用方法冲突。...如果真的相同,请在SQL语句中使用一对``(着重号)引起来。(键盘上1数字的旁边那玩意) 补充: SELECT 查询还可以对常数进行查询。对的,就是在 SELECT 查询结果中增加一列固定的常数列。...SQL 中的 SELECT 语法的确提供了这个功能,一般来说我们只从一个表中查询数据,通常不需要增加一个固定的常数列,但如果我们想整合不同的数据源,用常数列作为这个表的标记,就需要查询常数。...Key:表示该列是否已编制索引。 PRI表示该列是表主键的一部分; UNI表示该列是UNIQUE索引的一部分; MUL表示在列中某个给定值允许出现多次。
3.1MySQL如何使用索引 索引用于快速查找具有特定列值的行。如果没有索引,MySQL必须从第一行开始,然后遍历整个表以找到相关行。表越大,成本越高。...MySQL支持许多不同的存储引擎(表类型)和行格式。对于每个表,你可以决定使用哪种存储和索引方法。为你的应用选择适当的表格式可以大大改善性能。...3.6.4连接 ①在具有相同数据类型的不同表中声明具有相同信息的列,以加快基于相应列的连接。 ②保持列名简单,这样你就可以在不同的表中使用相同的名称,简化连接查询。...3.7.2字符和字符串类型 当比较不同列的值时,尽可能用相同的字符集和排序来声明这些列,以避免运行查询时的字符串转换。 对于小于8KB的列值,使用二进制varchar而不是blob。...当MySQL从行中检索任何值时,它读取一个包含该行所有列(可能还有其他相邻行)的数据块。保持每一行的大小并只包含最常用的列,使每个数据块可以容纳更多的行。
优化count count有两种不同的工作方式:统计值的数量和统计行的数量。值是一个非空的表达式(null意味着没有值)。...(*) from world.city where id <= 5; 使用一个查询统计一列中不同值的数量 select sum(if(color='blue',1,0)) as blue, sum(if...但这并不意味着每次在select中选择非分组的列都会得到同样的结果,可以通过配置sql_mode参数来禁止在select中使用未在group by中出现的列。...在一个分组查询中,select子句使用非分组的列通常都不是一个好主意,因为结果可能是不确定的,并且如果更改了索引或优化器采用了不同的策略,那么结果页可能被轻易地改变。...除非定义了order by,否则mysql会自动对group by里面的列进行排序。因此,如果显示包括一个含有相同列的order by子句,则对mysql的实际执行性能没有什么影响。
MySQL 的许多数据类型可以存储相同类型的数据,但在它们可以存储的值范围、允许的精度或所需的物理空间(在磁盘和内存中)方面有所不同。一些数据类型还具有特殊的行为或属性。...ENUM 列可以存储一组预定义的不同字符串值。MySQL 将它们非常紧凑地存储在 1 或 2 个字节中,具体取决于列表中值的数量。它将每个值内部存储为表示其在字段定义列表中位置的整数。...图 7-2 说明了索引如何排列存储的数据。 请注意,索引根据在CREATE TABLE语句中给出的列的顺序对值进行排序。看看最后两个条目:有两个名字相同但出生日期不同的人,它们按出生日期排序。...索引选择性是索引值的不同值数(基数)与表中总行数(#T)的比率,范围从 1/#T到 1。高度选择性的索引很好,因为它让 MySQL 在查找匹配项时过滤更多行。唯一索引的选择性为 1,这是最好的选择。...具体细节在不同的实现中有所不同,但 InnoDB 的聚集索引实际上将 B 树索引和行一起存储在同一结构中。 当表具有聚集索引时,其行实际上存储在索引的叶页中。
的结果总是有相同的列,每一列代表着不同的含义,可变的只是行数和内容。...2)id不同 如果存在子查询,id的序号会递增,id值越大优先级越高,越先被执行。...3)id相同又不同 1)、2)两种情况同时存在。id如果相同,认为是一组,从从上往下执行。在所有组中,id值越大,优先级越高,越先执行。...从上面的举例对比中,也充分印证了索引的重要性。 3)range 只检索给定范围的行,使用一个索引来选择行。key列显示使用了那个索引。...9. ref列 表示在key列记录的索引中查找值,所用的列或常量const。 10. rows列 估算出找到所需行而要读取的行数。
值选择它认为成本小的,但成本小并不意味着执行时间短)等等。...) 优化排序(在老版本MySQL会使用两次传输排序,即先读取行指针和需要排序的字段在内存中对其排序,然后再根据排序结果去读取数据行,而新版本采用的是单次传输排序,也就是一次读取所有的数据行,然后根据给定的列排序...使用B-Tree这个术语,是因为MySQL在CREATE TABLE或其它语句中使用了这个关键字,但实际上不同的存储引擎可能使用不同的数据结构,比如InnoDB就是使用的B+Tree。...理由非常简单,MySQL不知道选择哪个索引的查询效率更好,所以在老版本,比如MySQL5.0之前就会随便选择一个列的索引,而新的版本会采用合并索引的策略。...索引选择性是指不重复的索引值和数据表的总记录数的比值,选择性越高查询效率越高,因为选择性越高的索引可以让MySQL在查询时过滤掉更多的行。唯一索引的选择性是1,这是最好的索引选择性,性能也是最好的。
结果包含很多列 1 各列字段说明 1.1 id SELECT标识符。这是查询中SELECT的序列号,表示查询中执行select子句或者操作表的顺序。如果该行引用其他行的并集结果,则该值可为NULL。...sg on e.sa1 between sg.1osal and sg.hisal; id不同,如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行 explain select * from...emp e where e.deptno in (select d.deptno from dept d where d.dname = 'SALES'); id相同和不同的,同时存在:相同的可以认为是一组...1.4.9 ref 对于先前表中的每个行组合,将从该表中读取具有匹配索引值的所有行。...支持选择all,cpu,block io,context,switch,page faults等明细,来查看MySQL在使用什么资源上耗费了过高的时间,例如,选择查看cpu的耗费时间 show profile
值选择它认为成本小的,但成本小并不意味着执行时间短)等等。...) 优化排序(在老版本MySQL会使用两次传输排序,即先读取行指针和需要排序的字段在内存中对其排序,然后再根据排序结果去读取数据行,而新版本采用的是单次传输排序,也就是一次读取所有的数据行,然后根据给定的列排序...使用B-Tree这个术语,是因为MySQL在CREATE TABLE或其它语句中使用了这个关键字,但实际上不同的存储引擎可能使用不同的数据结构,比如InnoDB就是使用的B+Tree。...理由非常简单,MySQL不知道选择哪个索引的查询效率更好,所以在老版本,比如MySQL5.0之前就会随便选择一个列的索引,而新的版本会采用合并索引的策略。...索引选择性是指不重复的索引值和数据表的总记录数的比值,选择性越高查询效率越高,因为选择性越高的索引可以让MySQL在查询时过滤掉更多的行。唯一索引的选择性是1,这时最好的索引选择性,性能也是最好的。
值选择它认为成本小的,但成本小并不意味着执行时间短)等等。...) 优化排序(在老版本MySQL会使用两次传输排序,即先读取行指针和需要排序的字段在内存中对其排序,然后再根据排序结果去读取数据行,而新版本采用的是单次传输排序,也就是一次读取所有的数据行,然后根据给定的列排序...索引选择性是指不重复的索引值和数据表的总记录数的比值,选择性越高查询效率越高,因为选择性越高的索引可以让MySQL在查询时过滤掉更多的行。唯一索引的选择性是1,这是最好的索引选择性,性能也是最好的。...) 优化排序(在老版本MySQL会使用两次传输排序,即先读取行指针和需要排序的字段在内存中对其排序,然后再根据排序结果去读取数据行,而新版本采用的是单次传输排序,也就是一次读取所有的数据行,然后根据给定的列排序...索引选择性是指不重复的索引值和数据表的总记录数的比值,选择性越高查询效率越高,因为选择性越高的索引可以让MySQL在查询时过滤掉更多的行。唯一索引的选择性是1,这是最好的索引选择性,性能也是最好的。
EXPLAIN为SELECT语句中使用的每个表返回一行信息,它按照MySQL在处理语句时读取表的顺序列出输出中的表。...id相同,执行顺序相同,从上往下执行;id不同,id越大越先被执行。那什么情况下id相同,什么情况下不同呢?...对于连接查询来说,一个 SELECT关键字后边的 FROM 子句中可以跟随多个 表,所以在连接查询的执行计划中,每个表都会对应一条记录,但是这些记录的 id 值都是相同的,比如: EXPLAIN SELECT...有子查询的语句id可能相同也可能不同 为什么有可能相同也有可能不同的,那是因为查询优化器觉得这条包含子查询的语句可以使用连接查询进行优化, 就会对这条语句进行重写为连接查询,所以想知道查询优化器是否重写了查询语句...在解释id的例子中有。 UNION RESULT:MySQL 选择使用临时表来完成 UNION 查询的去重工作,针对该临时表的查 询的 select_type 就是 UNION RESULT。
插入多行; 4.插入某些查询的结果; - 注意,由于MySQL的安全机制,需要注意权限。 插入完整的行 需要指定插入的表名和行值。一般插入操作没有返回值,举例, 分析:第一列cust_id为。...这是因为在表中,该列由MySQL自动增量,所以指定一个值。 注意,虽然此语法简单,但并非安全。上面语句高度依赖表中列的次序。...因此当比给出列名的时候,必须正确的给出每列的值。 如果表的定义允许,可以选择在操作时忽略某些列。忽略的列必须满足如下条件, 1. 该列定义为允许; 2....同时检索列与插入列的名字不需要相同,MySQL只关心对应列顺序。 更新数据 注意,在使用语句时,必须严格小心,不要省略语句,否则会更新表中所有行。...2、为了删除每列的值,可以赋值为。 删除数据 使用语句,进行删除操作,形式如下 - 从表中删除特定行; - 从表中删除所有的行。
也可能会使用完全限定的名字来引用列。 WHERE 过滤数据 MySQL中可根据需要使用很多条件操作符和操作符的组合。为了检查某个范围的值,可使用BETWEEN操作符。 注意:是!=还是?!...NULL 与不匹配 在通过过滤选择出不具有特定值的行时,你可能希望返回具有 NULL 值的行。但是,不行。因为未知具有特殊的含义,数据库不知道它们是否匹配,所以在匹配过滤或不匹配过滤时不返回它们。...❑ 如果分组列中包含具有 NULL 值的行,则 NULL 将作为一个分组返回。如果列中有多行NULL值,它们将分为一组。...在升序排序时可以指定它。但实际上,指定 ASC 没有多大用处 在对文本性数据进行排序时,A 与a 相同吗?a位于 B 之前,还是Z之后?这些问题不是理论问题,其答案取决于数据库的设置方式。...所有这些限制以及更多的限制都可以用全文本搜索来解决。在使用全文本搜索时,MySQL不需要分别查看每个行,不需要分别分析和处理每个词。MySQL 创建指定列中各词的一个索引,搜索可以针对这些词进行。
找出表列(或所有行或某些特定的行)的最大值、最小值和平均值 如: AVG() 返回某列的平均值 COUNT() 返回某列的行数 MAX() 返回某列的最大值 MIN() 返回某列的最小值 SUM() 返回某列值之和...HAVING和WHERE的差别 这里有另一种理解方法,WHERE在数据分组前进行过滤,HAVING在数据分组后进行过滤。这是一个重要的区别,WHERE排除的行不包括在分组中。...虽然GROUP BY和ORDER BY经常完成相同的工作,但它们是非常不同的。 这里为什么说group by 与 order by完成相同的工作呢?...此外,用户也可能会要求以不同于分组的顺序排序。仅因为你以某种方式分组数据(获得特定的分组聚集值),并不表示你需要以相同的方式排序输出。...num_prods select 语句顺序: SELECT 要返回的列或表达式 是 FROM 从中检索数据的表 仅在从表选择数据时使用 WHERE 行级过滤 否 GROUP BY 分组说明 仅在按组计算聚集时使用
领取专属 10元无门槛券
手把手带您无忧上云