数据库入门级SQL优化

1. SELECT * FROM users;

优化原因 :使用SELECT *会选择所有列,可能导致不必要的数据传输。应只选择需要的列,例如:

复制代码
SELECT id, name FROM users;

2. WHERE age > 30;

优化原因 :如果age字段没有索引,查询速度会慢。可以考虑在age列上创建索引,或者使用范围查询结合索引。

3. SELECT name FROM users WHERE name LIKE '%john%';

优化原因:前缀通配符会导致全表扫描。可以重构查询或使用全文索引。

4. INSERT INTO orders (id, user_id, product_id) VALUES (1, 2, 3);

优化原因:在高并发情况下,批量插入能提高性能。可以改为:

复制代码
INSERT INTO orders (id, user_id, product_id) VALUES (1, 2, 3), (2, 3, 4);

5. SELECT * FROM orders WHERE user_id = 1 ORDER BY created_at;

优化原因 :如果没有索引,排序会影响性能。应在user_idcreated_at上创建复合索引。

6. UPDATE users SET last_login = NOW() WHERE id = 1;

优化原因:频繁更新同一行会导致行锁。可以考虑批量更新,或者在业务逻辑中减少操作频率。

7. DELETE FROM users WHERE created_at < '2020-01-01';

优化原因 :全表扫描会影响性能。可使用分区表或者在created_at上创建索引。

8. SELECT COUNT(*) FROM orders;

优化原因:全表扫描可能很慢。可以使用物化视图或维护一个单独的计数表。

9. SELECT * FROM products WHERE category_id IN (1, 2, 3);

优化原因 :如果category_id没有索引,查询会很慢。应在category_id上创建索引。

10. JOIN多个表时没有使用ON条件

复制代码
SELECT * FROM orders JOIN users;

优化原因 :缺失ON条件会导致笛卡尔积,产生大量不必要的数据。应明确指定连接条件。

相关推荐
折翼的恶魔17 分钟前
SQL 189 统计有未完成状态的试卷的未完成数和未完成率
数据库·sql
yangmf204022 分钟前
如何使用 INFINI Gateway 增量迁移 ES 数据
大数据·数据库·elasticsearch·搜索引擎·gateway
运维李哥不背锅2 小时前
Ansible 的条件语句与循环详解
数据库·ansible
梦里不知身是客112 小时前
hive的SQL语句练习2
hive·hadoop·sql
曾凡宇先生2 小时前
OpenEuler中mysql这是在执行 MySQL 密码重置操作时出现的 “找不到mysqld_safe命令” 的错误场景。
数据库·mysql
梦里不知身是客112 小时前
hive的SQL练习3
hive·hadoop·sql
方二华2 小时前
6 mysql源码中的查询逻辑
数据库·mysql
意疏3 小时前
LibreTV无广告观影实测:聚合全网资源,远程访问家庭影院新方案!
数据库
不见长安在3 小时前
mysql线上主从集群设置
数据库·mysql
tiging3 小时前
mysql 如何让事件执行
数据库·mysql