度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 1201|回复: 4
打印 上一主题 下一主题

[分享] Oracle执行SQL查询语句的步骤

[复制链接]

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
跳转到指定楼层
楼主
发表于 2020-2-13 17:57:33 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
如果用户在SQL*Plus下输入了如下查询语句:SELECT * FROM dept;
查询语句的处理主要包括三个过程:编译(parse)、执行(execute)和提取数据(fetch)。
  l 编译:在进行编译时,服务器进程将会将SQL语句的正文放入共享池(shared pool)的库高速缓存(library cache)中并将完成以下处理。
首先在共享池中搜索是否有相同的SQL语句(正文),如果没有就进行后续的处理。
    检查该SQL语句的语法是否正确。
    通过查看数据字典来检查表和列的定义。
    对所操作的对象加编译锁(parse locks),以便在编译语句期间,这些对象的定义不被改变。
    检查所引用对象的用户权限。
    生成执行该SQL语句所需的优化和执行计划(执行步骤)。
    将SQL语句和执行计划装入共享SQL区。
以上的每一步操作都是在处理正确时才进行后续的处理。如果不正确,就返回错误。
  l 执行:oracle服务器进程开始执行SQL语句是因为它已获得了执行的SQL语句所需要的全部资源和信息。
  l 提取数据:oracle服务器进程选择所需的数据行,并在需要时将其排序,最后将结构返回给用户(进程)。

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
5#
 楼主| 发表于 2020-2-14 17:43:59 | 只看该作者
回复 支持 反对

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
地板
 楼主| 发表于 2020-2-14 17:43:26 | 只看该作者
回复 支持 反对

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
板凳
发表于 2020-2-14 16:10:33 | 只看该作者
回复 支持 反对

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
沙发
 楼主| 发表于 2020-2-13 17:58:10 | 只看该作者
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-11-23 22:30 , Processed in 0.140661 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表