返回顶部
首页 > 资讯 > 数据库 >SQL命令优化需要记住的9点事项分别是什么
  • 529
分享到

SQL命令优化需要记住的9点事项分别是什么

2024-04-02 19:04:59 529人浏览 安东尼
摘要

sql命令优化需要记住的9点事项分别是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。与数据库交互的基本语言是sql,数据库每次解析和执

sql命令优化需要记住的9点事项分别是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

数据库交互的基本语言是sql,数据库每次解析和执行sql语句多需要执行很多步骤。以SQL Server为例,当数据库收到一条查询语句时,语法分析器会扫描sql语句并将其分成逻辑单元(如关键词、表达式、运算符和标识符)并生成查询树,最后查询优化器将分析所有可以访问数据库的源表的方法,从中选择一组返回结果集最快且消耗资源较少的步骤。查询树随即进行更新以准确记录这个步骤,接着交由数据库引擎开始执行,然后将查询结果返回给用户。可见数据库引擎每次执行sql命令都会有很大的开销,如果提交的sql质量不高甚至有逻辑错误就会造成无谓的开销和时间浪费。为了避免这种情况,在使用sql命令时应注意以下原则:

1、字段提取要按照“需多少、提多少”的原则,避免“select *”,尽量使用“select 字段1,字段2,字段3 ...”。实践证明,每少提取一个字段,数据库提取速度就会有相应的提升。提升的速度还要由你舍弃的字段大小来决定。

2、尽量使用exists代替select count(*) 来判断是否存在记录。优化器优化exists谓词时支持短路功能。只要找到一行,不需要再扫描其他行就可以确定该表是否包涵行了。count函数只有在统计表中所有行的行数时使用。

3、尽量使用(not) exists代替(not) in 操作,in的sql性能总是比较低的。

  --语句  select dname,deptno from dept where deptno not in(select deptno from emp where dept.deptno=emo.deptno)  --语句  select dname,deptno from dept where not exists(select deptno from emp where dept.deptno=emo.deptno)

4、尽量使用not in,可以用left outer join代替它。

5、尽量不要使用or,使用or会引起全表扫描,将大大降低查询效率

6、注意where子句的写法,必须考虑语句顺序,应该根据索引顺序、范围大小来确定条件子句的前后顺序,尽可能地让字段顺序与索引顺序一致,范围从大到小。

7、尽量使用“>=“,不用使用”>“

8、在编写sql语句之前了解表的索引结构。有效地利用索引能够避免不必要的全表扫描,缩短查询时间。应该避免在where子句中使用is null、<>、!=、not、 not exist、not in、not like等命令,他们通常会引起全表扫描导致索引无效。

9、在where 子句中,任何对列的操作(函数、计算等)讲导致索引失效,这些操作应该尽可能地移至等号右边,如where substring(id,1,1)=‘a‘,应该写成where id like 'a%‘;where result*10> 30应该写成where result >30;

对sql命令进行优化的基本原则是尽量减少类型转换和计算,充分利用表索引,减少全表扫描的次数。

关于SQL命令优化需要记住的9点事项分别是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网数据库频道了解更多相关知识。

您可能感兴趣的文档:

--结束END--

本文标题: SQL命令优化需要记住的9点事项分别是什么

本文链接: https://lsjlt.com/news/69042.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • SQL命令优化需要记住的9点事项分别是什么
    SQL命令优化需要记住的9点事项分别是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。与数据库交互的基本语言是sql,数据库每次解析和执...
    99+
    2024-04-02
  • 优化Kubernetes成本的9个办法分别是什么
    这篇文章将为大家详细讲解有关优化Kubernetes成本的9个办法分别是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Kubernetes统治着容器市场。根据CNCF的一项调查,到202...
    99+
    2023-06-15
  • ​SQL命令的4种类型分别是什么
    这篇文章给大家分享的是有关SQL命令的4种类型分别是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。SQL命令主要分为4种类型,分别为:DDL(数据定义语言)、DML(数据操作...
    99+
    2024-04-02
  • 升级SQL Server 2014的四个要点分别是什么
    这篇文章将为大家详细讲解有关升级SQL Server 2014的四个要点分别是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。升级并不容易,但是有一些特性...
    99+
    2024-04-02
  • 优化网页的六点技巧分别是什么
    这篇文章将为大家详细讲解有关优化网页的六点技巧分别是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。标题中要出现关键词。这个大家都知道,标题是搜索引擎排名算法中最重要的因素,你要优化哪个关...
    99+
    2023-06-12
  • 项目中常用的19条MySQL优化分别是是什么
    项目中常用的19条MySQL优化分别是是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、EXPLAIN做M...
    99+
    2024-04-02
  • 租用香港服务器需要注意的3点要求分别是什么
    本篇文章为大家展示了租用香港服务器需要注意的3点要求分别是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.租用香港服务器首先必需考虑第一条件,带宽是否足够香港国际独立带宽费用相对比较贵,2M国...
    99+
    2023-06-12
  • MySQL项目中常用的19条优化方法分别是什么
    MySQL项目中常用的19条优化方法分别是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。今天共提到19条常用的MySQL优...
    99+
    2024-04-02
  • 优化SQL SELECT语句性能的6个简单技巧分别是什么
    本篇文章给大家分享的是有关优化SQL SELECT语句性能的6个简单技巧分别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。SELECT语...
    99+
    2024-04-02
  • 用Python做数据科学时容易忘记的八个要点分别是什么
    本篇文章给大家分享的是有关用Python做数据科学时容易忘记的八个要点分别是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。  如果你发觉自己在编程时一次又一次地查找相同的问...
    99+
    2023-06-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作