测试文章笔记-SQL3种优化方法

SQL语句优化:

本质:降低执行时间
**核心思路:**找到执行计划中开销较高的操作,改写SQL语句或改变表访问方式调整执行计划。

举例:

1.使用索引替代全表扫描(索引:是帮助MysQL高效获取数据的数据结构(有序)。在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。

单列索引存在null会导致索引失效
总结:
让包含null值得列在检索时可以使用索引,需要将基于b树的单列索引改为复合索引,将原有索引修改为inx_code(code,0),(这里还是没有看懂,0是指什么列?还是特殊的表示手法?)再次执行查询,对user表的访问方式由全表扫描改为索引范围扫描,执行时间降至1秒之下。
“null值将使得索引失效”的原因:可能是因为code作为主键,不能为null导致。
b树单列索引:B-树索引是基于二叉树结构的。B-树索引结构有3个基本组成部分:根节点、分支节点和叶子节点。其中根节点位于索引结构的最顶端,而叶子节点位于索引结构的最底端,中间为分子节点。oracle和mongodb的索引都是B-Tree,而mysql的索引类型是B+Tree。
oracle:Oracle是大型数据库而Mysql是中小型数据库。
单列索引:只包含一个列
复合索引:包含两个或两个以上个列,与顺序有关联,窄索引指只有2个列、宽索引指有2个以上的列。

2、通过索引的有序性消除排序操作。
在这里插入图片描述
dec:降序排列
asc:升序排列

相关推荐

  1. 优化SQL方法

    2024-02-19 09:20:01       41 阅读
  2. 优化SQL方法

    2024-02-19 09:20:01       39 阅读
  3. clickhouse sql优化笔记

    2024-02-19 09:20:01       60 阅读
  4. SQL笔记 -- 查询优化

    2024-02-19 09:20:01       48 阅读
  5. MySQL优化:12提升SQL执行效率的有效方法

    2024-02-19 09:20:01       60 阅读
  6. SQL Server查询优化方法

    2024-02-19 09:20:01       42 阅读
  7. SQL优化方案示例

    2024-02-19 09:20:01       33 阅读
  8. sql优化学习笔记整理

    2024-02-19 09:20:01       63 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-19 09:20:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-19 09:20:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-19 09:20:01       87 阅读
  4. Python语言-面向对象

    2024-02-19 09:20:01       96 阅读

热门阅读

  1. AutoSAR(基础入门篇)7.3-使用DEV配置SWC&RTE

    2024-02-19 09:20:01       52 阅读
  2. Rust-所有权(ownership)

    2024-02-19 09:20:01       53 阅读
  3. Rust语言之sha-256爆破

    2024-02-19 09:20:01       49 阅读
  4. go redis

    go redis

    2024-02-19 09:20:01      42 阅读
  5. android pdf框架-3,对开源库的探究1

    2024-02-19 09:20:01       45 阅读
  6. 「优选算法刷题」:寻找数组的中心下标

    2024-02-19 09:20:01       54 阅读
  7. 5G固定无线接入(FWA)

    2024-02-19 09:20:01       54 阅读
  8. 民安智库如何做汽车满意度调查

    2024-02-19 09:20:01       48 阅读
  9. 汽车零部件软件开发常用搜索算法

    2024-02-19 09:20:01       43 阅读