天天看点

MySQL 第六篇:索引与子查询子查询索引

我把MySQL的内容整理成9篇博客,学完这9篇博客虽不能说能成为大神,但是应付一般中小企业的开发已经足够了,有疑问或建议的欢迎留言讨论。

子查询,从原有的查询语句中 嵌入新的查询 来得到我们想要的结果,也可称为嵌套查询。

1、查询课程名为“Java”的学生信息

2、用子查询实现查询出PHP 和 Java的学生

注意:

1、IN 的元素不能超过1000个。

2、in的效率会较低。有时候会用exists代替 in。

3、所有的关联查询都可以转换为子查询。但是并不是所有的子查询都能转化成关联查询。

把内层的查询结果集作为临时表 供外层sql再次查询。

例:

将学号为J1609004 的class_id更新成PHP的class_id

数据库索引:数据库管理系统中的一个排序的数据结构,以协助快速查询,更新数据库表中的数据。简单来说,建立了索引后会在数据库里面单独一块区域建立一个小空间,把数据排好序,这样查找起来就快得多。

a.数据库的存储空间的占用

b.插入或修改数据的时候要花费较多的时间 - 重新建立索引

a.单表数据太少,索引反而会影响速度,数据较少的表不需要建立索引

b.数据较多的情况下, where 后的条件、order by 、group by等过滤时,后面的字段最好加上索引,根据实际情况,选择primary key,unique index,索引不是越多越好。

c.联合查询,子查询等多表操作时对关联字段加索引。

语法:create index 索引名 on 表名(列名)

语法:create unique index 索引名 on 表名(列名)

语法:create index 索引名 on 表名(列名1,列名2.);

1、组合索引页可以是唯一索引。

2、当查询条件有组合查询的第一个字段(s_name)的时候就一定会用该索引去查询,无论where后面的查询条件的顺是怎样的,无论有没有其他查询条件。

1、在上例中,如果不存在索引,查找时将会扫描全表的s_name字段。

2、在一张表中可以建立多个所以,但是所以不是越多越好。

3、唯一索引的意思是这个字段的每个值都不一样,可以根据索引值唯一确定一条数据,而其他索引不能根据索引值确定唯一的数据。

修改语法:alter index 索引名 (生产系统不建议使用索引的修改,数据库执行时无法进行查询操作)

删除语法:drop index 索引名 on 表名

1.越小的数据类型越好。

2.简单的数据类型越好,给日期做索引的 使用datetime 。

3.尽量避免使用NULL,指定列为 not null 有空值的列很难进行查询优化。可以使用0或者一个特殊的值或者空字符串来代替。

优点:加快查询速度

缺点:降低增 改 删的速度,增大了表的文件大小