`

多表条件查询的性能优化

    博客分类:
  • SQL
阅读更多
多表条件查询的性能优化
sql1: select b.*,a.* from a,b where a.alt = b.alt and a.materialbill = b.mat and a.mtl = 'B01AE50131B3000AE' 

sql2: select b.*,a.* from a,(select alt,mat from b where mtlno = 'B01') b where a.alt = b.alt and a.mat = b.mat

大家写多表查询的时候可能经常会写成sql1的语句,虽然sql1和sql2所完成的结果是一致的不过效率上来讲sql2更高效。
下面是笔者对于sql1,和sql2执行效率的对比(在同环境中的100次执行 80%以上的情况下 sql1的执行时间是大于sql2的)
程序运行时间 sql1: 60642295ns
程序运行时间 sql2: 38701910ns

程序运行时间 sql1: 48397951ns
程序运行时间 sql2: 46428006ns

程序运行时间 sql1: 46488642ns
程序运行时间 sql2: 31040653ns

程序运行时间 sql1: 35065875ns
程序运行时间 sql2: 31788246ns

程序运行时间 sql1: 35922433ns
程序运行时间 sql2: 31519137ns

程序运行时间 sql1: 34986580ns
程序运行时间 sql2: 32410407ns

程序运行时间 sql1: 35279593ns
程序运行时间 sql2: 31643322ns

程序运行时间 sql1: 33958278ns
程序运行时间 sql2: 31290219ns

程序运行时间 sql1: 34027940ns
程序运行时间 sql2: 31123665ns

程序运行时间 sql1: 34309302ns
程序运行时间 sql2: 31402426ns

程序运行时间 sql1: 34546235ns
程序运行时间 sql2: 31409009ns

程序运行时间 sql1: 34160856ns
程序运行时间 sql2: 31276024ns

通过上面的结果可以看出sql2的执行效率更高效,当然如果只是有限的数据量这种性能可以忽略
分享到:
评论

相关推荐

    ORACLE多表查询优化

    Oracle 多表查询优化需要考虑多个方面,包括选择合适的表名顺序、使用 Cache Buffer、语句共享、优化查询路径、避免多表连接查询、优化数据统计、选择合适的索引、优化数据库结构、使用 Materialized View、优化...

    SQL_Server_2008查询性能优化

    总的来说,SQL Server 2008查询性能优化是一个涉及多个层面的综合过程,包括查询设计、索引管理、存储过程、数据库设计以及服务器配置等多个方面。通过深入理解和实践这些技巧,开发者可以显著提升其SQL代码的运行...

    ORACLE SQL性能优化系列

    ORACLE SQL性能优化系列 ORACLE SQL性能优化是数据库管理员和开发者非常关心的一个话题。为了提高数据库的性能,ORACLE 提供了多种优化技术。下面我们将详细介绍 ORACLE SQL 性能优化系列中的一些重要知识点。 一...

    SQLserver2008查询性能优化

    在SQL Server 2008中,查询...总的来说,SQL Server 2008查询性能优化涉及多个方面,包括但不限于索引的设计和管理、查询优化、资源使用监控等。正确地应用这些策略,将有助于构建一个响应迅速、效率高的数据库系统。

    oracle数据库性能优化.pdf

    总的来说,Oracle数据库性能优化是一个全面的过程,涵盖硬件配置、软件设置、SQL优化、存储策略等多个方面。需要根据系统负载、业务需求以及资源状况进行综合分析,持续监控和调整,以实现最优的数据库运行状态。...

    SQL Server 2008查询性能优化 源代码

    在SQL Server 2008中,查询性能优化是一项至关重要的任务,因为它直接影响到数据库系统的响应速度和整体效率。"SQL Server 2008查询性能优化源代码"这一资源提供了一种深入学习和实践的方法,帮助我们理解并提升SQL...

    EBS性能调优之全面挖掘_V4.2(ebs性能优化、oracle性能优化、linux性能优化)

    数据库层优化主要包括两个方面:实例性能优化和SQL语句性能优化。实例优化涉及内存配置、后台进程调整和初始化参数设置,以确保数据的高效读写和处理。SQL优化则侧重于通过分析SQL执行计划,识别慢查询并应用索引、...

    oracle性能优化技巧

    - 在多表连接的情况下,选择合适的交集表可以使查询更加高效。 #### 五、其他性能优化技巧 1. **WHERE子句优化**: - 将最限制性的条件放在WHERE子句的前面,可以更早地过滤掉不匹配的记录。 2. **避免使用...

    MySQL性能优化中文手册

    MySQL性能优化是数据库管理员和开发人员的关键技能,它涉及到如何有效地使用SQL语句、存储过程和函数,以提高数据查询速度和系统整体效率。本手册将深入探讨这些关键领域,帮助你理解并实施最佳实践。 在SQL语句...

    mysql多表查询和EXISTS查询性能对比

    ### MySQL多表查询和EXISTS查询性能对比 #### 测试环境 在进行MySQL多表查询与EXISTS查询的性能对比之前,首先需要了解测试环境的相关配置。虽然原文中并未给出具体的测试环境细节,但在实际操作中,这一步骤至关...

    db2数据库性能优化小技巧

    ### DB2数据库性能优化小技巧详解 #### 一、Bufferpool优化 在DB2数据库中,Bufferpool(缓冲池)的设置对整个系统的性能有着重要的影响。合理的Bufferpool配置能够显著提升数据访问速度,减少I/O操作次数。下面将...

    ORACLE-SQL性能优化大全.pdf

    通过以上知识点的详细阐述,我们可以看到Oracle SQL性能优化是一个涉及多个层面、多个方面的综合性任务。无论是从SQL语句本身出发,还是从数据库设计、实例配置等方面入手,都需要综合考虑多种因素,才能达到最佳的...

    高性能MySQL_ch04_查询性能优化.pdf

    通过以上分析可以看出,高性能MySQL查询性能优化是一个综合性的工作,需要从多个角度出发进行全面考虑。无论是SQL语句优化还是索引设计,都需要根据实际场景灵活运用各种技术手段。此外,还应该关注新的数据库特性和...

    ABAP程序性能优化

    2. **创建视图**:对于复杂的多表JOIN场景,考虑创建视图,从而简化查询过程并提高性能。 #### 结论 通过对这些关键性能优化技巧的理解和应用,开发者可以显著提升ABAP应用程序的性能。值得注意的是,优化不仅限于...

    Oracle性能优化与故障诊断案例分享

    Oracle数据库性能优化与故障诊断是数据库管理中极为重要的两个方面,它们直接关系到企业业务系统的稳定运行和性能表现。在这篇文章中,我们将详细探讨针对Oracle数据库性能问题和故障的诊断案例,并分享如何通过案例...

    Oracle数据库中大型表查询优化的研究

    综上所述,Oracle数据库中大型表查询优化涉及多个方面,包括索引优化、查询设计、工具利用、分区技术和数据库配置。每个环节都需要根据具体情况进行细致分析和调整,以实现最佳的查询性能。在实际操作中,应结合实际...

    PostgreSQL 性能优化宝典

    优化SQL语句是提升数据库性能的直接方式,例如通过减少不必要的数据表连接、合理使用索引、优化查询条件等方式来提高查询效率。 文档还提到了如何让数据库输出好的执行计划。这需要通过执行计划分析工具,比如...

    性能优化pdf (pdf格式ppt)

    ### 性能优化基础知识 #### 一、性能与性能优化概览 在IT领域中,特别是在软件开发和系统管理方面,“性能”是一个极为关键的概念。根据给定文档中的标题“性能优化pdf(pdf格式ppt)”及描述“性能优化专题之什么...

Global site tag (gtag.js) - Google Analytics