************************************************************************
  ****原文:blog.csdn.net/clark_xu 徐长亮的专栏
************************************************************************

1.1 变量

在匿名块或者存储过程中定义的变量为局部变量,及作用域在整个匿名块或存储过程中。执行结束,则该变量就不存在了;

绑定变量

在PLSQL的SQL中直接私有绑定变量:bv_name,不须要定义

1.1.1 
绑定变量的定义

--绑定变量的定义

variable I number

begin

for I in 1 .. 1000 loop

execute immediate ‘insert into test values(:i)’ using I;

:I :=I; ---绑定变量的赋值

end loop

dbms_output.put_line(:i);

commit;

end;

print i

exec :i=:=10000 --- 绑定变量的赋值

print :I;

3.3 PLSQL的SQL分类

静态SQL:

--在PLSQL块中使用的SQL语句在编译的时候是明白的,SQL语句在PLSQL编辑阶段编译。

动态SQL:

--PLSQL编译时SQL是不确定的,如依据用户输入參数的不同而运行不同的操作。

编译程序对动态语句不处理。在执行的时候,动态创建SQL语句

3.3.1 静态SQL

--一次硬分析,一次软分析。1000次运行

create or replace procedure proc1

ls

begin

for I in 1 .. 1000 loop

insert into test values(I);

end loop;

commit;

end;

begin proc1 end;

3.3.2 本地动态SQL(未使用绑定变量)

1000此硬分析,1000此软分析,1000次运行

create procedure proc1 ls

begin

for I In 1  ..1000 loop

execute immediate ‘insert into test values(‘||I||’)’;

end loop;

commit;

end;

---编译过程的时候,不编译sql语句

begin proc1 end;

3.3.3 本地动态SQL(使用绑定变量)

--1次硬分析。1000次软分析。1000次运行

create procedure proc1 ls

begin

for I In 1  ..1000 loop

execute immediate ‘insert into test values(:i)’ using i;

end loop;

commit;

begin proc1 end;

3.4 SQL语句的处理过程

语法检查:syntax check

语义检查:semantic check

--诸如检查sql语句中的訪问对象是否存储,该用户是否具备对应的权限。

对sql语句进行解析parse

--利用内部算法对sql进行解析,生成解析树(parse tree)及运行计划(execution plan)

运行sql,返回结果:execute and  return;

3.4.1 硬解析和软解析

oracle利用内部hash算法来获得该sql的hash值。然后在library
cache里查找是否存在该hash值;

如果存在,则将此sql与cache中的进行比較;如果“同样”。就将利用已有的解析数和运行计划,而忽略了优化器的相关工作,这就是软解析的过程。

假设上面两个降低中任由一个不成立,那么优化器都将进行创建解析树,生成运行计划的动作,这个过程都叫硬解析;

3.5 相应存储过程的操作

创建并编译过程:

create or replace procedure

编译过程

alter procedure procname compile;

调用过程

用匿名子程序调用,直接写过程名

用有名子程序调用,直接写过程名。

删除过程:

drop procedure

3.5.1 过程的使用案例

创建存储过程

create or replace procedure p_account

(p_id number,p_realname out varchar2,p_age out number)

ls

begin

select real_name,round((sysdate-birthdate)/360) into p_realname,p_age

from account

where id=p_id;

exception

when no_data_found then

p_realname :=’no account’;

p_age:=0;

end;

有名子程序调用:

declare

v_realname varchar2(20);

v_age number;

begin

p_account(1011,v_realname,v_age);

dbms_output.put_line(v_realname || ‘’ || v_age);

end;

匿名子程序调用,绑定变量:

variable b_realname varchar2(20)

variable b_age number

begin

p_account(1011,:b_realname,:b_age);

end;

print b_realname;

print b_age;

3.6 PLSQL中的静态sql

oracle在解析sql时候会把PLSQL中定义的变量转为绑定变量insert into test values(:b1),降低硬解析的次数;

server process将运行完的sql cache起来,不关闭,当再运行sql。不须要软解析;

过程中的參数会自己主动转化为绑定变量。

************************************************************************
  ****原文:blog.csdn.net/clark_xu 徐长亮的专栏
************************************************************************

版权声明:本文博主原创文章,博客,未经同意不得转载。

【PLSQL】绑定变量,活跃SQL,软硬解析解析的更多相关文章

  1. 使用EXECUTE IMMEDIATE来生成含有绑定变量的SQL

    一个SQL,通过SPM固定它的执行计划,可以通过DBMS_SPM.LOAD_PLANS_FROM_CURSOR_CACHE实现.也可以通地此功能在不修改原SQL的情况下对其加HINT来固定执行计划.D ...

  2. 包含绑定变量的sql进行调优需注意一点

    拿1个sql举个例子,我只贴出了where后面部分 实际环境中有init_date 和direct_no的组合索引IDX_DATE_NO 上诉标红处,:b3=0 和:b3<>0这两种情况o ...

  3. Oracle SQL调优之绑定变量用法简介

    目录 一.SQL执行过程简介 二.绑定变量典型用法 2.1.在SQL中绑定变量 2.2.在PL/SQL中使用绑定变量 2.3.PL/SQL批量绑定变量 2.4.Java代码里使用绑定变量 最近在看&l ...

  4. PLSQL使用绑定变量

    想对一个sql做10046trace,结果因为10g数据库无法对sql_id做,只能使用绑定变量的方法,下面sql是如何使用绑定变量运行sql的语句 declare  v_sql  VARCHAR2( ...

  5. [转]ORACLE 绑定变量用法总结

    转:http://blog.csdn.net/wanghai__/article/details/4778343 在oracle 中,对于一个提交的sql语句,存在两种可选的解析过程, 一种叫做硬解析 ...

  6. ORACLE 绑定变量用法总结 .

    之前对ORACLE中的变量一直没个太清楚的认识,比如说使用:.&.&&.DEIFINE.VARIABLE……等等.今天正好闲下来,上网搜了搜相关的文章,汇总了一下,贴在这里,方 ...

  7. OTL翻译(5) -- otl_stream流相关绑定变量

    声明绑定变量 本章节将详细的说明如何在otl_stream流里面声明绑定变量. SQL语句.SQL语句块或存储过程在程序里面使用的时候总是带有占位符.OTL里面带有一个小的解析器用来解析这些占位符,并 ...

  8. otl_stream流相关绑定变量

    声明绑定变量 本章节将详细的说明如何在otl_stream流里面声明绑定变量. SQL语句.SQL语句块或存储过程在程序里面使用的时候总是带有占位符.OTL里面带有一个小的解析器用来解析这些占位符,并 ...

  9. ORACLE绑定变量隐式转换导致性能问题

    年后一次系统升级后,监控数据库的工具DPA发现数据库的Total Wait时间突然飙增,如下截图所示,数据库的总体等待时间对比升级前飙增了非常多 另外就是发现出现了较多的等待事件,主要有latch: ...

随机推荐

  1. Paip.断点调试MYSQL存储过程跟函数的解决方案大法

    Paip.断点调试MYSQL存储过程跟函数的解决方案大法 作者Attilax ,  EMAIL:1466519819@qq.com  来源:attilax的专栏 地址:http://blog.csdn ...

  2. UVA 10160 Servicing Stations(深搜 + 剪枝)

    Problem D: Servicing stations A company offers personal computers for sale in N towns (3 <= N < ...

  3. 使用BigDecimal来进行精确计算

    在一些以金融等行业中的计算是需要十分精确的,即使我们使用像double这样的类型,由于浮点数的原因,会使得数据计算变得不精确,例如下面的例子: double a = 0.1; double b = 0 ...

  4. Windows 8 动手实验系列教程 实验5:进程生命周期管理

    动手实验 实验5:进程生命周期管理 2012年9月 简介 进程生命周期管理对构建Windows应用商店应用的开发者来说是需要理解的最重要的概念之一.不同于传统的Windows应用(它们即使在后台仍然继 ...

  5. POJ训练计划3041_Asteroids(二分图/最小点覆盖=最大匹配)

    解题报告 http://blog.csdn.net/juncoder/article/details/38135053 题目传送门 题意: 给出NxN的矩阵,有M个点是障碍 每次仅仅能删除一行或者一列 ...

  6. NET Platform Standard

    NET Platform Standard 相关博文:ASP.NET 5 Target framework dnx451 and dnxcore50 .NET Platform Standard:ht ...

  7. Tair是一个高性能,分布式,可扩展,高可靠的key/value结构存储系统(转)

    Tair是一个高性能,分布式,可扩展,高可靠的key/value结构存储系统! Tair专为小文件优化,并提供简单易用的接口(类似Map)Tair支持Java和C版本的客户端 Tair is a di ...

  8. 页面提交错误,页面间参数传递java.lang.NumberFormatException: null

    多次出现这样的错误,在点击一个按钮触发提交整个页面的事件时,总是报错,不止一次出现这样的错误了. 出现这种问题的分析: 1 我们从这个问题的本身来看,java.lang.NumberFormatExc ...

  9. Android 特殊符号的转码大全

    项目中要在string.xml 中显示特殊符号,如@号冒号等,直接写肯定不行啦..只能考虑使用ASCII码进行显示: @号 @ :号 : 空格   以下为常见的ASCII十进制交换编码: --> ...

  10. 更好的自动ssh登录

    更好的自动ssh登录 解决~/.ssh/known_hosts 过期问题. bash + expect bash:ssh.sh #!/bin/bash help(){ echo "usage ...