sql语句执行顺序

徐克达

学习SQL语句,最重要的一点就是它的执行顺序。如果执行顺序搞不清楚,在写SQL语句时只能在试验中检测正确与否。那么SQL语句执行循序是什么呢?

sql语句执行顺序

SQL语句执行顺序

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

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

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

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

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

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

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

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

9)运行“执行计划”

SQL关键字和参数描述

bind_argument

一个传递到动态SQL语句的表达式值(IN绑定),或是一个存储动态SQL语句返回值的变量(OUT绑定)。

BULK COLLECT INTO

如果使用仅当动态SQL语句可以返回多行,此子句指定一个或多个集合存储返回行。该子句必须有一个相应的兼容型集合或数组来存储动态SQL语句的查询列。

collection_name

一个声明的集合,用来存储动态SQL语句返回行。

dynamic_returning_clause

如果使用仅当动态SQL语句有RETURNING INTO子句,这个子句返回动态SQL语句受影响行的列值,独立变量或记录。该子句可以包括OUT绑定参数。

dynamic_sql_stmt

一个字符串常量,字符串变量,或表示SQL语句的字符串表达式,必须是CHAR、VARCHAR2或者CLOB类型。

host_array_name

返回行数组进行存储,该数组必须声明一个PL / SQL主机环境中,并传递给PL/ SQL绑定参数(冒号(:)前缀)

IN, OUT, IN OUT

绑定参数的参数模式,IN绑定参数传递值到动态SQL语句,OUT绑定参数存储动态SQL语句返回值。IN OUT绑定参数传递初始值到动态SQL语句,并存储动态SQL语句返回值。默认绑定参数的参数模式是IN。

INTO

当且仅当动态SQL语句是一个SELECT语句,最多可以返回一行。此子句指定变量或记录存储返回行的列值。对于每个动态SQL语句查询列,必须有相应的自定义变量兼容类型和记录兼容类型。

record_name

存储返回行的用户自定或%rowtype记录。

USING

当且仅当动态SQL语句包含占位符,指定绑定参数列表。

热门推荐

2021年9月计算机二级成绩什么时候公布

2021年9月计算机二级成绩什么时候出 怎么查

注册网约车需要什么条件

注册网约车需要什么条件

自己怎么报考人力资源管理师

命题说话编不下去了怎么办

直播口才训练方法

Python就业方向有哪些 发展前景怎么样

学python有什么好处 学完可以做什么

webservice和restful区别