Oracle执行SQL查询语句的步骤

Oracle执行SQL查询语句的步骤

如果用户在SQL*Plus下输入了查询语句如:SELECT * FROM emp;在SQL语句执行查询的过程步骤,Oracle与Mysql不同,关于Mysql的我的博客也有写。

SQL语句的执行主要由用户进程与服务器进程来完成的,其他的一些进程可能要辅助完成这一过程。查询语句与其他的SQL语句有所不同,如果一个查询语句执行成功,就要返回查询的结果,而其他的SQL语句只是返回执行成功或失败的信息。

查询语句的处理主要包括:编译(parse)、执行(execute)和提取数据(fetch)。
1.编译:在进行编译时,服务器进程会将SQL语句的正文放入共享池(shared pool)的库高速缓存(library cache)中并将完成以下处理:

a.首先在共享池中搜索是否有相同的SQL语句,如果没有就进行后续的处理;
b.检查该SQL语句的语法是否正确;
c.通过查看数据字典来检查表和列的定义;
d.对所操作的对象加编译锁(parse locks),以便在编译语句期间这些对象的定义不能被改变;
e.检查所引用对象的用户权限;
f.生成执行该SQL语句的所需的优化的执行计划(执行步骤);
g.将SQL语句和执行计划装入共享的SQL区。

以上的每一步操作都是在处理正确时才进行后续的处理,如果不正确,就返回错误。

2.执行(execute):Oracle服务器进程开始执行SQL语句是因为它已获得了执行SQL语句所需的全部资源和信息。
3.提取数据(fetch):Oracle服务器进程选择所需的数据行,并在需要时将其排序,最后将结果返回给用户进程。

借鉴于:《Oracle数据库管理》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

偷偷学习被我发现

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值