Oracle执行SQL查询语句的步骤

本文介绍了Oracle数据库中SQL查询语句的执行过程,包括编译、执行和提取数据三个主要阶段。并详细解释了每个阶段的具体操作,如语法检查、权限验证及执行计划生成等。

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

Oracle执行SQL查询语句的步骤

查询语句和其他语句不同,如果查询语句执行成功,会返回查询结果,而其他类型的SQL语句只是返回执行成功或者失败的信息。

Oracle处理查询语句分为3大阶段:编译(parse)、执行(execute)、提起数据(fetch)。
  • 编译(parse):在进行编译时,服务器进程会将SQL语句的内容放入共享池(shared pool)的库高速缓存(library cache)中,并完成以下处理:
    • 首先在共享池中查询是否包含相同的SQL语句,如果没有就进行后续的处理。
    • 检查SQL语句语法是否正确。
    • 查看数据字典来检查SQL语句相关表和列的定义。
    • 对 SQL语句所操作的对象添加编译锁(parse locks),使得在编译语句期间,这些对象的定义不会改变。
    • 检查用户对SQL语句所引用的对象是否有权限。
    • 生成该SQL的执行计划。
    • 将SQL语句和执行计划放入共享的SQL区。
  • 执行(execute):Oracle服务器进程开始执行编译后的SQL语句。
  • 提取(fetch): Oracle服务器进程选择所需的数据行,并在需要时将其排序,最后将结果返回给用户进程。

转载于:https://my.oschina.net/pkpk1234/blog/57237

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值