oracle SQL解析步骤小结
1 The syntax of the SQL statement is verified.
SQL的语法检查
2 The data dictionary is searched to verify table and column definitions.
从数据字典检查表名和字段名
3 The data dictionary is searched to verify security privileges on relevant objects.
从数据字典中检查权限
4 Parse locks are acquired on the relevant objects.
解析相关对象的锁
5 The optimal execution plan is determined.
选在执行计划运行SQL
6 The statement is loaded into the shared SQL area (also known as the library cache) in the shared pool of the system global area (SGA).
执行后SQL语句放在SGA的SQL共享区
相关推荐
-
oracle SQL解析步骤小结
1 The syntax of the SQL statement is verified. SQL的语法检查 2 The data dictionary is searched to verify table and column definitions. 从数据字典检查表名和字段名 3 The data dictionary is searched to verify security privileges on relevant objects. 从数据字典中检查权限 4 Parse lo
-
ORACLE SQL语句优化技术要点解析
操作符优化: IN 操作符 用IN写出来的SQL的优点是比较容易写及清晰易懂,这比较适合现代软件开发的风格. 但是用IN的SQL性能总是比较低的,从ORACLE执行的步骤来分析用IN的SQL与不用IN的SQL有以下区别: ORACLE试图将其转换成多个表的连接,如果转换不成功则先执行IN里面的子查询,再查询外层的表记录,如果转换成功则直接采用多个表的连接方式查询. 由此可见用IN的SQL至少多了一个转换的过程.一般的SQL都可以转换成功,但对于含有分组统计等方面的SQL就不能转换了. 推荐方案:
-
Oracle SQL tuning 数据库优化步骤分享(图文教程)
SQL Turning 是Quest公司出品的Quest Central软件中的一个工具.Quest Central是一款集成化.图形化.跨平台的数据库管理解决方案,可以同时管理 Oracle.DB2 和 SQL server 数据库. 一.SQL Tuning for SQL Server简介 SQL语句的优化对发挥数据库的最佳性能非常关键.然而不幸的是,应用优化通常由于时间和资源的因素而被忽略.SQL Tuning (SQL优化)模块可以对比和评测特定应用中SQL语句的运行性能,提出智能化的
-
PL/SQL编程经验小结开发者网络Oracle
正在看的ORACLE教程是:PL/SQL编程经验小结开发者网络Oracle.平时在PL/SQL中的编程中遇到一些问题,这里以问答的形式来进行把它们总结下来,以供大家分享. 1.当需要向表中装载大量的数据流或者需要处理大量的数据流的时候,能否使用管道提高处理效率? 管道函数对于改善并行查询的性能非常方便,它加快往表中加载数据的速度.管道函数的使用总结如下两点: 每当在查询里使用PL/SQL函数时,该查询将被序列化,即一个处理器只能运行一个查询实例,那么在这种情况下不可能使用并行查询(比如在数据仓库
-
Oracle硬解析和软解析的区别分析
一.摘要 Oracle硬解析和软解析是我们经常遇到的问题,所以需要考虑何时产生软解析何时产生硬解析,如何判断 SQL的执行过程 当发布一条SQL或PL/SQL命令时,Oracle会自动寻找该命令是否存在于共享池中来决定对当前的语句使用硬解析或软解析. 通常情况下,SQL语句的执行过程如下: Step1. SQL代码的语法(语法的正确性)及语义检查(对象的存在性与权限). Step2. 将SQL代码的文本进行哈希得到哈希值. Step3. 如果共享池中存在相同的哈希值,则对这个命令进一步判断是否进
-
MySQL学习之SQL语法及SQL解析顺序
目录 SQL语言分类 SQL语法顺序和解析顺序 FROM ON OUTER JOIN WHERE GROUP BY HAVING SELECT DISTINCT ORDER BY LIMIT SQL(Structured Query Language)是一种标准,作为一种访问[关系型数据库的标准语言].许多数据库产品,如Oracle,DB2,SQL Server,PostgreSQL,MySQL都支持它.近几年的NoSQL最初是宣称不再需要SQL,后来也不得不修正为Not Only SQL,来拥
-
MySQL与Oracle SQL语言差异比较一览
数据类型 编号 ORACLE MYSQL 注释 1 NUMBER int / DECIMAL DECIMAL就是NUMBER(10,2)这样的结构INT就是是NUMBER(10),表示整型: MYSQL有很多类int型,tinyint mediumint bigint等,不同的int宽度不一样 2 Varchar2(n) varchar(n) 3 Date DATATIME 日期字段的处理 MYSQL日期字段分DATE和TIME两种,ORACLE日期字段只有DATE,包含年月日时分秒信息,用当前
-
oracle sql执行过程(流程图)
Oracle sql执行流程图_SQL执行过程一.sql语句的执行步骤:1)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义.2) 语义分析,检查语句中涉及的所有数据库对象是否存在,且用户有相应的权限.3)视图转换,将涉及视图的查询语句转换为相应的对基表查询语句.4)表达式转换, 将复杂的 SQL 表达式转换为较简单的等效连接表达式.5)选择优化器,不同的优化器一般产生不同的"执行计划" 6)选择连接方式,ORACLE有三种连接方式,对多表连接ORACLE可选择适当的连
-
Oracle SQL性能优化系列学习二
正在看的ORACLE教程是:Oracle SQL性能优化系列学习二. 4. 选择最有效率的表名顺序(只在基于规则的优化器中有效) ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,因此FROM子句中写在最后的表(基础表 driving table)将被最先处理. 在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表.当ORACLE处理多个表时, 会运用排序及合并的方式连接它们.首先,扫描第一个表(FROM子句中最后的那个表)并对记录进行派序,然后扫描第二个表(
-
oracle 性能优化建议小结
原则一:注意WHERE子句中的连接顺序: ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾. 尤其是"主键ID=?"这样的条件. 原则二: SELECT子句中避免使用 ' * ': ORACLE在解析的过程中, 会将'*' 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间 . 简单地讲,语句执行的时间越短越好(尤其对于系统的终端用
随机推荐
- Lua 数学库的所有函数功能作用一览
- 详解angularjs中如何实现控制器和指令之间交互
- 浅谈Java工程读取resources中资源文件路径的问题
- java 设计模式之State(状态模式)
- Python中getattr函数和hasattr函数作用详解
- Linux下安装oracle客户端并配置php5.3
- php生成zip压缩文件的方法详解
- python中利用Future对象异步返回结果示例代码
- 零基础写python爬虫之打包生成exe文件
- 基于Java 谈回调函数
- C/C++ 中堆和栈及静态数据区详解
- PHP5.3连接Oracle客户端及PDO_OCI模块的安装方法
- 学习JavaScript事件流和事件处理程序
- JQuery教学之性能优化
- 基于jquery用于查询操作的实现代码
- 谈谈javascript中使用连等赋值操作带来的问题
- db_owner权限得到webshell我的两点改进
- C语言通讯录管理系统完整版
- 代码详解java里的“==”和“equels”区别
- Python闭包执行时值的传递方式实例分析