`

Oracle数据库之PLSQL绑定变量

阅读更多
--=========绑定变量=================
--====绑定变量
--- 在PL/SQL的sql直接使用绑定变量:bv_name

variable k number; --声明k是绑定变量
--打印k的值
print k; -- 结果 是没有值

exec :k :=1000; --绑定变量赋值	 
print k; -- 结果 1000

--===匿名块使用绑定变量===
declare
	i number(4) :=1;
begin
	 dbms_output.put_line('i:' || i);
	:k :=i; -- 绑定变量赋值
	 dbms_output.put_line('k:' || :k);
end;

-- 分析绑定变量的作用
--需求:向test表中的c1列添加数据 1.. 100 loop

-- 静态SQL
CREATE OR replace procedure p1
	is
begin
	for i in 1 .. 100 loop
		insert into  t1 values (i);
	end loop;
	commit;
end;--编译过程阶段完成 dml语句的编译

--执行
begin
	p1 -- 1次硬分析 1次软分析  100次执行
end; 

--动态SQL ,没使用绑定变量
create or replace procedure p1
	is
begin
	for i in 1 .. 100 loop
	execute immediate 'insert into t1 values ('|| i || ')';
	end loop;
	execute immediate 'commit';
end; --编译过程,不会编译insert 

--执行
begin
	p1 -- 100次硬分析 100次软分析  100次执行
end; 


--动态 sql +绑定变量
variable num number;
create or replace procedure p1 
	is
begin
	for i in 1..100 loop
			-- :a是占位符  
		execute immediate 'insert into t1 values (:a)' using i;
	end loop;
	execute immediate 'commit';
end;

--执行
begin
	p1 -- 1次硬分析 100次软分析  100次执行
end; 


--======软解析硬解析
--- Oracle利用内部的hash算法来取得该sql的hash值,然后在
----libray cache(PGA里面的一块区域) 里查找是否存在该hash值.

----假设存在相同的hash值,则将此sql与cache中的进行比较,
--假设'相同',就将利用已有的解析树与执行计划,而省略了优化器相关工作,这就是软解析的过程.

----如果上面两个假设条件有一个不成立,那么优化器都将创建解析树,
----生成执行计划的动作,这个过程叫硬解析.



--===========PL/SQL中的静态SQL====
---Oracle在解析SQL时会把pl/sql中定义的变量转为绑定变量
---insert into test values (:a1);减少硬分析次数
---Server process将执行完的SQL cache起来,不关闭.当再次执行sql时,不需要软分析.
---过程中的参数自动转化为绑定变量







 

分享到:
评论

相关推荐

    PLSQL绑定变量用法小结归纳.pdf

    PLSQL绑定变量用法小结归纳 绑定变量是PLSQL中的一种强大工具,能够提高数据库的性能和可扩展性。在Oracle中,对于一个提交的SQL语句,存在两种可选的解析过程,一种叫做硬解析,一种叫做软解析。硬解析需要经解析...

    PLSQL绑定变量用法小结[收集].pdf

    总的来说,绑定变量是提高Oracle数据库性能的关键技术之一,尤其在处理大量动态或重复执行的SQL语句时,能显著减少解析开销,提升系统整体性能。因此,理解和熟练掌握绑定变量的使用对于任何Oracle数据库开发者来说...

    Oracle12c客户端+plsql12

    同时,了解和运用绑定变量、缓存策略等,能进一步提升系统效率。 总之,Oracle 12c客户端和PL/SQL 12c为开发者提供了强大而全面的工具,用于创建、管理及优化与Oracle数据库交互的应用程序。理解并掌握这些特性将极...

    VC6访问Oracle数据库

    为了最大化效率,可以使用绑定变量、预编译的SQL语句、批量执行等技术。同时,优化SQL查询,减少网络传输的数据量,以及合理设计数据库结构和索引,都能有效提升性能。 8. **安全性**: 不要忘记考虑安全因素,...

    Oracle+PLSQL+语法手册 全面 详细 chm

    1. 使用绑定变量减少解析次数,提高执行效率。 2. 适当使用索引优化查询速度。 3. 分析和调整SQL语句,避免全表扫描。 4. 使用存储过程和函数封装复杂逻辑,减少网络传输。 总结,"Oracle+PLSQL+语法手册"是一本...

    Oracle11g PLSQL Programming(pdf & source)

    12. **性能优化**:PL/SQL代码的性能调优技巧,包括使用绑定变量、避免硬解析等。 13. **动态SQL**:运行时构建SQL语句的能力,允许程序更具灵活性和适应性。 压缩包中的"Oracle11gPLSQLProgramming.pdf"可能是这...

    精通Oracle10g PLSQL编程

    Oracle 10g PLSQL编程是数据库管理员和开发人员掌握Oracle数据库系统的关键技能之一。PL/SQL,全称Procedural Language/Structured Query Language,是Oracle数据库提供的一个强大的过程化编程语言,它融合了SQL查询...

    oracle数据库开发工具

    14. **性能优化**:通过索引、绑定变量、物化视图、分区等技术,可以显著提升PL/SQL程序的执行效率。 综上所述,"PLsql"标签表明该压缩包可能包含有关PL/SQL编程的资料,如教程、示例代码或实战项目。学习和掌握PL/...

    oracle特有的错误:ORA-01036:非法的变量名/编号

    在示例代码中,`:id`是一个Oracle风格的绑定变量,而不是SQL Server中的`@id`。 2. **参数绑定问题**:在OracleCommand对象中,当使用参数化查询时,必须使用`:var_name`的格式来定义参数。如代码所示,`cmd....

    Oracle PLSQL程序设计

    4. **安全性**:确保代码遵循安全编程的最佳实践,如使用绑定变量防止SQL注入攻击。 通过以上介绍,我们可以了解到Oracle PL/SQL作为一种强大的数据库编程语言,不仅能够简化数据库操作,还能提高应用的安全性和...

    OCI操作oracle数据库

    使用`OCIParse`解析SQL或PL/SQL语句,然后通过`OCIBindByPos`或`OCIBindByName`绑定变量,最后用`OCIStmtExecute`执行语句。对于DML(数据操纵语言)操作,如INSERT、UPDATE、DELETE,OCI会返回受影响的行数。 5. ...

    PLSQL用于Oracle交互

    10. **性能优化**:学习如何通过索引、物化视图、绑定变量等方式优化PLSQL代码,提高数据库的执行效率。 通过掌握以上知识点,开发者不仅可以有效地与Oracle数据库进行交互,还能编写出高效、健壮的PLSQL代码,提高...

    oracle-PLSQL实例精析

    8. **性能优化**:学习如何编写高效的PL/SQL代码,减少数据库访问,利用绑定变量提升性能。 9. **事务管理**:掌握BEGIN、COMMIT、ROLLBACK语句,理解事务的概念和其在保持数据一致性中的关键角色。 10. **数据库...

    ORACLE PLSQL

    2. **使用绑定变量**:避免硬解析,通过使用绑定变量使相同SQL语句能够重用解析计划。 3. **索引优化**:合理使用索引,特别是在WHERE子句中频繁出现的列上,可以显著提升查询速度。 4. **适当的数据类型选择**:...

    Oracle SQL and PLSQL Bad Practices

    - 使用绑定变量来构建动态 SQL 语句。 - 对输入进行严格的验证和清理。 **例外情况**:在非常受控的环境中,可能允许少量硬编码字符串。 #### 结论 以上列出的只是 Oracle SQL 和 PL/SQL 开发中众多不良实践的一...

    Oracle PLSQL编程,第4版

    这包括索引策略、子查询优化、使用绑定变量以及避免全表扫描等技巧。 10. **高级特性**:如包(PACKAGE)、存储过程、存储函数、触发器、类型对象等,这些高级特性让PL/SQL功能更加强大,能够实现复杂的业务逻辑。 ...

    精通Oracle 10g plsql编程

    - **绑定变量**:减少解析开销,提高多用户并发环境下的性能。 - **PL/SQL执行计划分析**:通过EXPLAIN PLAN等工具理解SQL的执行方式。 6. **安全性与权限管理** - **角色和权限**:如何分配和管理用户对数据库...

    Oracle PLSQL实例精解(英文原书第4版)

    书中会解释如何使用EXECUTE IMMEDIATE语句以及绑定变量来实现动态SQL,同时强调了安全性和性能优化的重要性。 书中还会涉及PL/SQL中的事务管理,包括COMMIT、ROLLBACK和SAVEPOINT操作。掌握事务管理对于保证数据...

    Oracle+PLSQL+高级程序设计

    Oracle数据库是全球最广泛使用的商业关系型数据库管理系统之一,它提供了强大的数据存储、管理和处理能力。PL/SQL(Procedural Language/Structured Query Language)是Oracle数据库中的过程化编程语言,与SQL紧密...

    Oracle9i PLSQL 从入门到精通

    2. **绑定变量**:减少硬解析,提高SQL执行效率。 3. **索引和分区**:合理设计索引和分区策略,提升查询速度。 在"Oracle9i PLSQL 从入门到精通.pdf"这本书中,读者将深入学习上述各个方面的知识,并通过实例和...

Global site tag (gtag.js) - Google Analytics