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

SQL语句优化:

本质 :降低执行时间

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

举例:

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


总结:

让包含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:升序排列

相关推荐
wanzehongsheng14 分钟前
光伏公共设施通信协议与物联网管理平台技术选型笔记
人工智能·笔记·物联网·能源·光伏·光伏支架·光伏太阳花
数智工坊19 分钟前
周志华《Machine Learning》学习笔记--第五章--神经网络
人工智能·笔记·神经网络·学习·机器学习
就叫飞六吧35 分钟前
关于 PowerShell 核心 API 的系统性科普
笔记
三品吉他手会点灯42 分钟前
C语言学习笔记 - 45.运算符和表达式 - 运算符3 - 逻辑运算符
c语言·笔记·学习
烬、、、1 小时前
如何用 Claude Code 调用 gpt-image2 生成图片?
人工智能·笔记·gpt·prompt·skills
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.06.04 题目:3751. 范围内总波动值 I
笔记·算法·leetcode
数智工坊1 小时前
周志华《Machine Learning》学习笔记--第七章--贝叶斯分类器
人工智能·笔记·神经网络·学习·机器学习
问心无愧05131 小时前
ctf show web入门99
android·前端·笔记
8Qi81 小时前
LeetCode 746:使用最小花费爬楼梯 —— 题解笔记
java·笔记·算法·leetcode·动态规划
二哈赛车手1 小时前
新人笔记---继图片搜索功能后续以及AI网络搜索功能一些经验与踩坑点,吐槽一下自己在做这方面的崩溃瞬间
java·网络·人工智能·spring boot·笔记·spring