Oracle sql语句执行顺序

本文详细介绍了Oracle SQL语句的执行步骤,包括词法分析、语法分析、语义分析等,并探讨了Oracle的共享原理,解释了如何提高查询效率,特别强调了硬解析与软解析的过程,以及在编写SQL时应注意的优化策略。
摘要由CSDN通过智能技术生成

sql语法的分析是从右到左

一、sql语句的执行步骤:

1)词法分析,词法分析阶段是编译过程的第一个阶段。这个阶段的任务是从左到右一个字符一个字符地读入源程序,即对构成源程序的字符流进行扫描然后根据构词规则识别单词(也称单词符号或符号)。词法分析程序实现这个任务。词法分析程序可以使用lex等工具自动生成。

2)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义。

3)语义分析,检查语句中涉及的所有数据库对象是否存在,且用户有相应的权限。

4)视图转换,将涉及视图的查询语句转换为相应的对基表查询语句。

5)表达式转换, 将复杂的 SQL 表达式转换为较简单的等效连接表达式。

6)选择优化器,不同的优化器一般产生不同的“执行计划”

7)选择连接方式, ORACLE 有三种连接方式,对多表连接 ORACLE 可选择适当的连接方式。

8)选择连接顺序, 对多表连接 ORACLE 选择哪一对表先连接,选择这两表中哪个表做为源数据表。

9)选择数据的搜索路径,根据以上条件选择合适的数据搜索路径,如是选用全表搜索还是利用索引或是其他的方式。

10)运行“执行计划”

二、oracle 共享原理:

 ORACLE将执行过的SQL语句存放在内存的共享池(shared buffer pool)中,可以被所有的数据库用户共享。

当你执行一个SQL语句(有时被称为一个游标)时,如果它和之前的执行过的语句完全相同,ORACLE就能很快获得已经被解析的语句以及最好的执行路径.。这个功能大大地提高了SQL的执行性

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值