SQL优化

文章主要介绍了SQL查询的优化方法,包括避免使用`SELECT*`,确保字段类型匹配,减少`ORDERBY`的使用,以及明智地处理`NULL`和表连接。同时,建议合理创建索引,避免过多索引影响写操作,并遵循最左原则。另外,文章提倡使用JOIN代替子查询,以及避免使用破坏索引的操作如`NOTIN`和`<>`。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、sql语法优化

1、尽量避免使用select *语句,应当明确查询具体字段,同时使用选择语句准确定位数据。
2、对于条件来说等号之类两边的字段类型要一致,字符串不加单引号索引会失效。
3、尽量少使用Order By排序,对于需要多个字段进行排序的可以使用组合索引。
4、对于group by语句要先过滤后分组。
5、在查询时减少使用null,对字段有多个null的可以加默认值。
6、在where后面少使用函数或者算数运算。
7、不要超过5个以上的表连接。
8、去除的distinct过滤字段要少,避免distinct * 。

二、建立索引

1、对于高频筛选字段可以适当的建立索引;
2、一个表的索引最好不要超过5个,多了会影响插入修改;
3、不要对值是有限重复的字段建立索引,如性别等;
4、使用组合索引一定要遵守最左原则;

三、sql代替优化

1、不要使用not in和<>,这个会破坏索引,not in可以用not exists来代替,<>可以分成两个条件>或都等;

2、使用连接(join)来代替子查询;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值