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语句包含占位符,指定绑定参数列表。