SQL优化可以从那几个方面去优化
视频:link
视频2:周瑜老师的不错的周老师
什么是索引??
索引是一种在数据库中用于加速查询的技术。它通过将数据存储在一个特殊的数据结构中,使得能够快速查找到数据。这样,在执行查询时就不必扫描整个数据表,从而大大加快查询的执行速度。
常见的索引类型包括:
主键索引:主键索引是一种强制性的索引,它强制使用唯一的值来标识表中的每一行。主键索引用于确保数据库中没有重复的行,并且常常被用来连接其他表。
唯一索引:唯一索引也是一种强制性的索引,但它允许表中有空值。它确保表中每一列的值都是唯一的,但并不要求每一行都是唯一的。
普通索引:普通索引是一种选择性的索引,它并不强制使用唯一的值来标识表中的每一行。普通索引常用于加速常见的查询,例如查询某一列的特定值。
索引可以大大加快数据库的查询速度,但是它们也有一些缺点。
索引缺点:
需要更新索引,这会导致操作变慢。因此,在设计数据库时,要谨慎地选择哪些列需要创建索引。
另外,当查询的数据量很大时,索引本身也可能成为瓶颈。这是因为索引本身也需要占用空间,如果索引过大,可能会导致内存不足或磁盘读写性能下降。
总的来说,索引是一种很有用的工具,但要谨慎使用,以免带来意想不到的问题。
MySQL支持多种类型的索引。常见的索引类型包括:
普通索引(index):普通索引是最常见的索引类型,它通过使用B-Tree算法维护索引。普通索引可以加速单列查询,但是无法加速范围查询或排序。
唯一索引(unique):唯一索引与普通索引类似,但它强制保证索引列中的值是唯一的。唯一索引可以加速单列查询和防止重复值。
主键索引(primary key):主键索引是一种特殊的唯一索引,它在表中必须存在,并且用于标识表中的每一行。主键索引可以加速单列查询和防止重复值。
全文索引(fulltext):全文索引是一种用于文本搜索的特殊索引,它使用MySQL的全文搜索引擎来维护索引。全文索引可以加速文本搜索查询,但无法用于数值或日期类型的列。
空间索引(spatial):空间索引是一种用于处理空间数据的特殊索引,它使用MySQL的空间数据类型和函数来维护索引。空间索引可以加速
1、基本写法优化;
1、少使用select * ,尽量使用具体字段;
2、对于条件来说等号之类两边的字段类型要一致,字符串不加单引号索引会失效;
3、尽量少使用Order By 排序,对于需要多个字段进行排序的可以使用组合索引;
4、对于group by 语句要先过滤后分组;
5、在查询时减少使用null,对字段有多个null的可以加默认值;
6、少使用like,对于需要使用的, 如需要使用尽量用 like abc%这种,不要把%放字段前面;
7、在where后面少使用函数或者算数运算;
8、去除的distinct 过滤字段要少,避免 distinct * ;
9、不要超过5个以上的表连接。
2、建立使用合适索引;
1、对于高频筛选字段可以适当的建立索引;
2、一个表的索引最好不要超过5个,多了会影响插入修改;
3、不要对值是有限重复的字段建立索引,如性别等;
4、使用组合索引一定要遵守最左原则;
3、替代优化
1、不要使用not in 和<>,这个会破坏索引,not in 可以用not exists 来代替,<>可以分成两个条件 >或者<等;
2、使用连接(join)来代替子查询;