SQL语句效率问题的几点总结

1. sql优化的原则是:

  将一次操作需要读取的BLOCK数减到最低,即在最短的时间达到最大的数据吞吐量。   
  调整不良SQL通常可以从以下几点切入:   
  检查不良的SQL,考虑其写法是否还有可优化内容   
  检查子查询   考虑SQL子查询是否可以用简单连接的方式进行重新书写   
  检查优化索引的使用   
  考虑数据库的优化器

2. 避免出现SELECT   *   FROM   table     语句,要明确查出的字段。     
    
3. 在一个SQL语句中,如果一个where条件过滤的数据库记录越多,

    定位越准确,则该where条件越应该前移。   
    
4. 查询时尽可能使用索引覆盖。即对SELECT的字段建立复合索引,

    这样查询时只进行索引扫描,不读取数据块。

5. 在判断有无符合条件的记录时建议不要用SELECT   COUNT   (*)和select   top   1   语句。   
    
6. 使用内层限定原则,在拼写SQL语句时,将查询条件分解、分类,

    并尽量在SQL语句的最里层进行限定,以减少数据的处理量。   
    
7. 应绝对避免在order   by子句中使用表达式。   
    
8. 如果需要从关联表读数据,关联的表一般不要超过7个。   
    
9. 小心使用   IN   和   OR,需要注意In集合中的数据量。建议集合中的数据不超过200个。   
    
10.    用      代替,>用>=代替,<用<=代替,这样可以有效的利用索引。   
    
11. 在查询时尽量减少对多余数据的读取包括多余的列与多余的行。   
    
12. 对于复合索引要注意,例如在建立复合索引时列的顺序是F1,F2,F3,

     则在where或order   by子句中这些字段出现的顺序要与建立索引时的字段顺序一致,

    且必须包含第  一列。只能是F1或F1,F2或F1,F2,F3。否则不会用到该索引。 

13. 多表关联查询时,写法必须遵循以下原则,这样做有利于建立索引,提高查询效率。

     格式如下

     select   sum(table1.je)   from   table1   table1,     table2     table2,               

     table3     table3   where   (table1的等值条件(=))   and   (table1的非等值条件) 

     and   (table2与table1的关联条件)   and (table2的等值条件)   and   (table2的非等值条件)    

     and (table3与table2的关联条件)   and   (table3的等值条件)   and   (table3的非等值件)。   
     注:关于多表查询时from     后面表的出现顺序对效率的影响还有待研究。   
    
14. 子查询问题。对于能用连接方式或者视图方式实现的功能,不要用子查询。

BibiGPT-哔哔终结者 BibiGPT-哔哔终结者

B站视频总结器-一键总结 音视频内容

BibiGPT-哔哔终结者 28 查看详情 BibiGPT-哔哔终结者

     例如:select   name    from   customer   where  

     customer_id   in   (   select     customer_id   from   order   where   money>1000)。

     应该用如下语句代替:select   name   from   customer  

    inner   join   order   on     customer.customer_id=order.customer_id  

    where   order.money>100。   
    
15. 在WHERE   子句中,避免对列的四则运算,

     特别是where   条件的左边,严禁使用运算与函数对列进行处理。

     比如有些地方   substring   可以用like代替。   
    
16. 如果在语句中有not   in(in)操作,

     应考虑用not   exists(exists)来重写,最好的办法是使用外连接实现。   
      
17. 对一个业务过程的处理,应该使事物的开始与结束之间的时间间隔越短越好,

     原则上做到数据库的读操作在前面完成,数据库写操作在后面完成,避免交叉。

18. 请小心不要对过多的列使用列函数和order   by,group   by等,谨慎使用disti软件开发t。   
    
19. 用union   all   代替   union,数据库执行union操作,

     首先先分别执行union两端的查询,

     将其放在临时表中,然后在对其进行排序,过滤重复的记录。   
     当已知的业务逻辑决定query   A和query   B中不会有重复记录时,

     应该用union   all代替union,以提高查询效率。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/421629.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 09:33:10
下一篇 2025年11月7日 09:40:01

相关推荐

  • 如何在Flask中从HTML按钮获取变量值

    本教程详细讲解了如何在flask应用中,通过html表单的post请求,安全有效地从按钮(或其他表单元素)获取动态变量值。我们将重点介绍html ` POST 请求: 立即学习“前端免费学习笔记(深入)”; 特点: 数据放在HTTP请求体中,不会显示在URL中,因此更适合发送敏感信息(如密码)或大量…

    2025年12月23日
    000
  • 在ASP.NET MVC中实现基于Chosen插件的3字符自动补全搜索

    本文旨在提供一个详细的教程,指导开发者如何在ASP.NET MVC应用程序中,结合Chosen.js插件,为大型下拉列表实现高效的3字符自动补全搜索功能。我们将涵盖从前端JavaScript事件监听、AJAX异步通信,到后端C#控制器数据处理的全栈实现细节,并提供最佳实践建议,以优化用户体验和系统性…

    好文分享 2025年12月21日
    000
  • 高效地将PostgreSQL jsonb数据传递到JavaScript

    本文旨在探讨如何高效地将PostgreSQL jsonb字段中已存在的JSON数据通过PHP传递到JavaScript,避免不必要的重复编码和解析。核心方法是在PHP中直接拼接从数据库获取的JSON字符串,构建成一个完整的JSON数组字符串,然后将其传递给JavaScript进行一次性解析,从而优化…

    2025年12月20日
    100
  • C++如何进行数据库操作_使用SQLiteCpp库在C++中轻松管理SQLite数据库

    SQLiteCpp简化C++中SQLite操作,需先安装libsqlite3-dev并编译SQLiteCpp库,通过包含头文件使用;用SQLite::Database创建或打开数据库,结合RAII与异常处理确保安全;利用exec()执行建表等DDL语句,通过SQLite::Statement预编译实…

    2025年12月19日
    000
  • c++怎么连接和使用SQLite数据库_c++ SQLite数据库连接与操作示例

    首先通过包含sqlite3.h和sqlite3.c在C++中连接SQLite,接着用sqlite3_open创建数据库,再使用sqlite3_exec执行建表、插入等操作,然后通过回调函数处理查询结果,推荐使用sqlite3_prepare_v2和绑定参数进行安全的预编译语句操作,最后正确释放资源完…

    2025年12月19日
    000
  • XSLT扩展函数如何编写?

    XSLT扩展函数通过外部代码(如Java、C#)增强XSLT处理能力,解决其在数据库操作、复杂计算、文件交互等方面的局限。以Java为例,需编写包含静态方法的类,将其置于classpath,并在XSLT中通过xmlns:prefix=”java:package.Class”声…

    2025年12月17日
    000
  • XQuery与SQL有何异同?

    XQuery专精于处理XML半结构化数据,适用于层次复杂、结构多变的场景,如Web服务、配置文件和数据转换;SQL则擅长管理高度结构化的二维表数据,适用于需强一致性与事务支持的业务系统。两者数据模型根本不同:SQL基于关系代数,强调表、行、列的刚性结构;XQuery基于XDM节点树模型,通过XPat…

    2025年12月17日
    000
  • python包和模块的内容整理

    模块是包含Python代码的文件,包是包含多个模块的目录,通过__init__.py识别;使用import导入模块,from…import导入函数;包内可用相对或绝对导入,建议用绝对导入并合理命名,以提升项目结构清晰度与可维护性。 Python 中的包(Package)和模块(Modul…

    2025年12月14日
    000
  • python psutil库有何用法?

    psutil 是跨平台 Python 库,用于监控系统资源,支持获取 CPU 使用率(psutil.cpu_percent(interval=1))、核心数(cpu_count)、CPU 时间(cpu_times);内存方面提供物理内存(virtual_memory)和交换分区(swap_memor…

    2025年12月14日
    000
  • Python 解释器的几种常见实现

    CPython是官方标准实现,用C编写,支持广泛但多线程受GIL限制;2. Jython将Python编译为Java字节码,适用于JVM平台并可调用Java库,但不支持C扩展且版本更新慢;3. IronPython运行在.NET平台,支持与C#交互,适合Windows和.NET集成,同样不兼容多数C…

    2025年12月14日
    000
  • Matplotlib SVG 文件添加元数据注释:使用 metadata 参数

    Matplotlib 允许用户在保存 SVG 文件时嵌入元数据注释。本文将详细介绍如何利用 plt.savefig 函数的 metadata 参数,遵循 Dublin Core 标准,为 SVG 图形文件添加创建者(Creator)等信息,从而有效记录文件来源和上下文,提升文件可追溯性。 1. 为什…

    2025年12月14日
    000
  • python中GIL的原理

    GIL是CPython为简化内存管理而引入的互斥锁,确保同一时刻仅一个线程执行字节码。由于CPython使用引用计数,需保证其增减的原子性,故通过GIL避免多线程竞争。在Python 3.2后,GIL采用抢占机制,持有超过5毫秒会主动释放,I/O或C扩展时也会释放以提升并发效率。GIL主要影响CPU…

    2025年12月14日
    000
  • 获取最新会议论文数据的OpenReview API与替代方案

    本文旨在提供一套全面的指南,教授如何利用OpenReview API获取学术会议(特别是2023年及以后)的论文标题和其他相关数据。鉴于API版本迭代,我们将重点介绍如何使用`openreview.api.OpenReviewClient`及其新的`baseurl`以访问最新数据。同时,针对部分会议…

    2025年12月14日
    000
  • CCXT fetch_ohlcv 最新数据缺失:时区问题的深度解析与解决方案

    在使用CCXT的`fetch_ohlcv`方法获取K线数据时,用户常遇到无法获取最新几小时数据的问题。这通常是由于将本地时间而非UTC时间作为`since`参数传入所致。CCXT及其底层交易所API普遍采用UTC时间戳。本文将深入探讨这一时区差异问题,并提供确保正确获取最新历史K线数据的解决方案和最…

    2025年12月14日
    000
  • python有哪些编译器

    答案是Python的“编译器”通常指不同实现或工具:CPython将源码编译为字节码并解释执行;PyPy通过JIT提升性能;Jython在JVM上运行;IronPython集成.NET;Cython生成C扩展;Nuitka编译为可执行文件;mypyc优化类型化代码。 Python 本身是一种解释型语…

    2025年12月14日
    000
  • CCXT fetch_ohlcv数据获取:时区处理与最新K线完整性指南

    使用ccxt的`fetch_ohlcv`方法获取最新ohlcv数据时,用户常遇到数据缺失,尤其是在请求特定时间范围时。这通常是由于未正确处理时区造成的。ccxt默认处理utc时间戳,而用户可能传入了本地化时间。本文将深入探讨这一常见问题,提供正确的时区处理策略和代码示例,确保您能准确无误地获取到最新…

    2025年12月14日
    000
  • PyMongo连接MongoDB Atlas认证失败:深度排查与解决方案

    本文详细探讨了使用pymongo连接mongodb atlas时常见的认证失败问题,特别是`bad auth`错误。文章将指导用户系统性地检查连接字符串、ip白名单和数据库用户权限。重点强调,在所有配置看似正确的情况下,创建新的数据库用户账户往往是解决此类顽固认证问题的有效且直接的方案,避免不必要的…

    2025年12月14日
    000
  • PyMongo认证失败疑难排解:从基础配置到用户账户异常处理

    pymongo连接mongodb atlas时,即使连接字符串、ip白名单和用户权限配置看似无误,仍可能遭遇认证失败。本教程将提供一套全面的排查指南,从基础配置检查到高级故障排除策略,并重点介绍一种针对性解决方案:当所有常规方法无效时,尝试重新创建具有相同权限的用户账户,以解决潜在的内部账户状态问题…

    2025年12月14日
    000
  • 获取会议论文数据:OpenReview API v2 与 Web 抓取实践指南

    本文将指导读者如何有效获取2023年及以后学术会议的论文数据。针对openreview平台上的会议,我们将介绍如何使用其更新的api v2接口,以解决旧版api无法访问新数据的挑战。对于如cvpr等采用独立开放访问站点的会议,则提供基于python的web抓取解决方案,帮助您高效提取论文标题及相关信…

    2025年12月14日
    000
  • Python Turtle模块bgpic()函数图片格式兼容性指南

    本教程详细解析python turtle模块`bgpic()`函数在使用时遇到的图片格式兼容性问题。我们将探讨`bgpic()`函数对不同图片格式的支持限制,特别是针对常见的`.png`文件报错原因,并提供将图片转换为`.gif`格式的解决方案及示例代码,确保背景图片能正确加载。 理解turtle.…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信