关系数据库SQL五条经验教训

您可以用多种不同的方式编写 SQL 查询。

下面是 5 条经验教训:

1、避免过度索引

索引是加快数据检索速度的有力工具。

索引的工作原理是创建一个额外的数据结构,数据库可以利用它来定位行。

避免过度索引;每个索引都需要更多存储空间,并会减慢写入操作速度。

在搜索条件(WHERE、JOIN)和排序(ORDER BY)中使用的列上创建索引。

在分区数据库中,索引的处理变得更加棘手

2、查询结构影响性能。

带有子查询和嵌套逻辑的复杂查询会迫使数据库工作更多。

有时,运行单独的查询并在服务器端添加这些查询是有意义的。

只选择必要的列可以减少数据库需要处理和传输的数据。

3、注意 JOIN 和 WHERE

  • JOIN 根据相关列合并两个或多个表中的记录。

  • WHERE 筛选记录。

  • JOIN 和 WHERE 子句可以减少查询后期需要处理的记录。

利用索引的优势编写 WHERE 和 JOIN。

4、子查询需要小心处理

外部查询中的每一行都会执行相关的子查询,从而导致效率低下。

将子查询改写为 JOIN 或使用临时表可以提高性能。

5、数据结构会影响查询性能。

数据规范化包括组织结构好处是:减少冗余和提高数据完整性。

但这可能会导致使用许多 JOIN 的复杂查询。

去规范化以增加数据冗余为代价,但是简化了查询;去规范化让事务变得更加复杂。

https://www.jdon.com/69638.html

相关推荐
竹林8183 小时前
用 wagmi v2 + viem 监听链上事件,我踩了三天坑终于搞懂了实时日志与历史补全
javascript
只一3 小时前
😭从回调地狱到 async/await:一文打通 Ajax 与 JS 异步编程
javascript
weedsfly4 小时前
语法糖褪去之后——Babel 转译产物中的 JavaScript 本貌
前端·javascript
JustHappy4 小时前
「软件设计思想杂谈🤔」“切图仔”也能懂编译原理?框架源码也许没那么难。聊聊 Vue 的编译(上)
前端·javascript·vue.js
晓得迷路了5 小时前
栗子前端技术周刊第 134 期 - React Router v8、TypeScript 7 RC、React Native 0.86...
前端·javascript·react.js
代码煮茶20 小时前
React 组件封装方法论 —— 以 Todo App 为例
javascript·react.js
任沫20 小时前
Agent之Function Call
javascript·人工智能·go
默_笙1 天前
🛬 我让 AI 帮我写了一个打飞机游戏,结果 Canvas 把我整不会了
前端·javascript
梯度不陡1 天前
AI 到底能不能从零写软件?ProgramBench 和 RepoZero 给出了两种答案
前端·javascript·面试
胡萝卜术1 天前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试