我把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或者一个特殊的值或者空字符串来代替。
优点:加快查询速度
缺点:降低增 改 删的速度,增大了表的文件大小