• 首页
  • 职业教育
  • 安全员证
  • 托福
  • 雅思
  • 小学
  • 一级建造师
  • 会计
  • 社会工作者
  • 您现在的位置: 首页 > 职业教育 >
    sql语句执行顺序
    时间:2025-07-22 16:38:46

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

    了解 【技能培训】更多资讯
    版权所有