SQL优化

1.插入数据

  • insert优化

  • 大批量插入数据

此时可以使用MySQL数据库提供的load指令进行插入。操作如下:

2.主键优化

  • 数据组织方式

表数据都是根据主键顺序组织存放的,这种存储方式的表称为索引组织表(IOT)

  • 页分裂

页可以为空,也可以填充一半,也可以填充100%。每个页包含了2-N行数据(如果一行数据多大,会行溢出),根据主键排列

  • 页合并

当删除一行记录时,实际上记录并没有被物理删除,只是记录被标记为删除并且它的空间变得允许被其他记录声明使用。

当页中删除的记录达到MERGE_THRESHOLD(默认为页的50%),InnoDB会开始寻找最靠近的页看看是否可以将两个页合并以优化空间使用

  • 主键设计原则 

尽量降低主键的长度

插入数据时,尽量选择顺序插入,选择使用AUTO_INCREMENT自增主键

尽量不要使用UUID做主键或者是其他自然主键,如身份证号

业务操作时,避免对主键的修改

3.order by 优化

①: Using Filesort:通过表的索引或全表扫描,读取满足条件的数据行,然后在排序缓冲区sort buffer中完成排序操作,所有不是通过索引直接返回排序结果的排序都叫FileSort排序

②:Using index:通过有序索引顺序扫描直接返回有序数据

4.group by优化

5.limit优化

6.count优化

7.update优化

相关推荐

  1. <span style='color:red;'>Sql</span><span style='color:red;'>优化</span>

    Sql优化

    2024-07-15 06:26:01      45 阅读
  2. SQL优化

    2024-07-15 06:26:01       44 阅读
  3. SQL优化

    2024-07-15 06:26:01       39 阅读
  4. sql优化

    2024-07-15 06:26:01       30 阅读
  5. <span style='color:red;'>SQL</span><span style='color:red;'>优化</span>

    SQL优化

    2024-07-15 06:26:01      29 阅读
  6. SQL 优化

    2024-07-15 06:26:01       33 阅读
  7. <span style='color:red;'>SQL</span><span style='color:red;'>优化</span>

    SQL优化

    2024-07-15 06:26:01      31 阅读

最近更新

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

    2024-07-15 06:26:01       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 06:26:01       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 06:26:01       58 阅读
  4. Python语言-面向对象

    2024-07-15 06:26:01       69 阅读

热门阅读

  1. RocketMQ

    RocketMQ

    2024-07-15 06:26:01      24 阅读
  2. SpringBoot实战:定时任务

    2024-07-15 06:26:01       20 阅读
  3. .NET 开源库技术栈汇总

    2024-07-15 06:26:01       19 阅读
  4. UDP 报文结构与注意事项全解析

    2024-07-15 06:26:01       27 阅读
  5. 深入理解Symfony框架中的数据验证机制

    2024-07-15 06:26:01       21 阅读
  6. OpenCV——实现视频图像的来回摆动的效果

    2024-07-15 06:26:01       17 阅读
  7. 【c++】VSstudio win32 应用开发

    2024-07-15 06:26:01       23 阅读
  8. 深入理解Scikit-learn:决策树与随机森林算法详解

    2024-07-15 06:26:01       22 阅读