Oracle绑定变量如何提升相关效率 (oracle数据库)

技术教程 2025-05-04 09:28:16 浏览
Oracle绑定变量如何提升相关效率

当我们把一个sql语句提交完后,Oracle绑定变量会检查一下在共享缓冲池(shared pool)中有无与之完全相同的相关语句,如果有的话只须执行软分析即可,否则就得进行硬分析。以下就是文章的具体内容介绍。而唯一使得oracle 能够重复利用执行计划的方法就是采用绑定变量。绑定变量的实质就是用于替代sql语句中的常量的替代变量。绑定变量能够使得每次提交的sql语句都完全一样。

在字段(包括字段集)建有索引,且字段(集)的集的势非常大(也就是有个值在字段中出现的比例特别的大)的情况下,使用绑定变量可能会导致查询计划错误,因而会使查询效率非常低。这种情况最好不要使用绑定变量。

但是并不是任何情况下都需要使用绑定变量,下面是两种例外情况:

1.对于隔相当一段时间才执行一次的SQL语句,这是利用绑定变量的好处会被不能有效利用优化器而抵消

2.数据仓库的情况下。

绑定变量不能当作嵌入的字符串来使用,只能当作语句中的变量来用。不能用Oracle绑定变量来代替表名、过程名、字段名等.

从效率来看,由于Oracle10G放弃了RBO,全面引入CBO,因此,在10G中使用绑定变量效率的提升比9i中更为明显。

举例:

普通sql语句:

SELECT fname, lname, pcode FROM cust WHERE id = 674;

SELECT fname, lname, pcode FROM cust WHERE id = 234;

SELECT fname, lname, pcode FROM cust WHERE id = 332;

含绑定变量的sql 语句:

SELECT fname, lname, pcode FROM cust WHERE id = :cust_no;

Sql*plus 中使用Oracle绑定变量:

SQL> set timing on

SQL> variable x number;

SQL> exec 😡 :=8

PL/SQL 过程已成功完成。

已用时间: 00: 00: 00.03

SQL> select * from A;

已用时间: 00: 00: 00.06

SQL> INSERT into A values(:x);

已创建 1 行。

已用时间: 00: 00: 00.01

SQL> select * from A;

已用时间: 00: 00: 00.01

PL/SQL很多时候都会自动绑定变量而无需编程人员操心,即很多你写得sql语句都会自动利用Oracle绑定变量,如下例所示:

SQL> Set timing on

SQL> declare

4 for I IN 1..1000 LOOP

5 INSERT INTO A VALUES(I);

PL/SQL 过程已成功完成。

已用时间: 00: 00: 00.12

这段代码是不需要使用Oracle绑定变量的方法来提高效率的,Oracle会自动将其中的变量绑定。

SQL> create table D ( id varchar(10));

表已创建。

已用时间: 00: 00: 00.50

SQL> declare

3 sqlstr varchar(2000);

oracle数据库

5 for i in 1..1000 loop

6 sqlstr :=’ insert into d values(‘||to_char(i)||’)’;

7 execute immediate sqlstr;

oracle数据库

PL/SQL 过程已成功完成。

已用时间: 00: 00: 00.68

这段代码同样是执行了1000条insert语句,但是每一条语句都是不同的,因此Oracle会把每条语句硬解析一次,其效率就比前面那段就低得多了。如果要提高效率,不妨使用绑定变量将循环中的语句改为

SQL> declarev

3 sqlstr varchar(2000);

5 for i in 1..1000 loop

6 sqlstr :=’ insert into d values(:i)’;

7 execute immediate sqlstr using i;

PL/SQL 过程已成功完成。

已用时间: 00: 00: 00.18

这样执行的效率就高得多了。

在PL/SQL中,引用变量即是引用绑定变量。但是在pl/sql中动态sql并不是这样。在vb,java以及其他应用程序中都得显式地利用Oracle绑定变量。对于绑定变量的支持不仅仅限于Oracle,其他RDBMS向SQL SERVER也支持这一特性。

【编辑推荐


vb公共模块里怎么写与数据库连接的简单代码

简单的做法很简单,如果在一个窗体中加私有的你会,那么把那段移到新建的一个模块中就行了,将connection对应的变量定义为Public然后定一个公共函数,在函数里中进行设置连接字符串,open这个connection等操作你可以这样设计。 定义一个对话框,这个对话框允许用户输入数据库的相关信息,比如SQL SERVER地址,用户名,密码,如果是Access数据,你可以在这个对话框让用户指定数据库所在位置。 然后将这信息保存成配置文件。 正常情况应用程序启动是加载这个信息,然后进行数据库连接,如果连接失败,显示出那个设置数据库参数的对话框,如果参数正确,这继续加载其他主窗体。 在应用程序任何地方想进行数据库操作直接使用那个公共的Connection就可以了,不需要在进行Open操作了。 程序要退出前,在关闭数据库等

oracle存储过程有没有对象的概念? 就是在定义参数的时候能不能定义一个对象呢?

你所谓的指的是type吧?变量类型。 要不然的话,就没有对象的概念了。

怎样在hibernate的HQL语句中使用mysql 的自定义函数

这时就需要重新定义hibernate的方言(dialect),将你需要用到的进行注册; 这里提到一个方言(dialect)的概念:Hibernate底层依然使用SQL语句来执行数据库操作,虽然所有关系型数据库都支持使用标准SQL语句,但所有数据库都对标准SQL进行了一些扩展,所以在语法细节上存在一些差异,因此Hibernate需要根据数据库来识别这些差异。 而方言(dialect)就是用来区分hibernate对应哪种数据库 通常在使用Spring整合hibernate的时候,会有这样一段配置=5InnoDBDialect _sql=true =none _sql=true _class= _mode=auto =1 =false _query_cache=false _second_level_cache=false _size=25 _size=50 其中红色的配置语句就是指明使用mysql方言,对于其他不同的数据库都有对应不同的方言,详情点击这里。 首先创建一个mysql函数,我们命名为my_change_local(number bigint) --这里是使用navicat工具创建的函数 BEGIN DECLARE stemp varchar(255); set stemp=; select into stemp from sms where =number; RETURN stemp; END 1.重写方言类,注册函数 public class MyLocalDialect extends MySQL5InnoDBDialect { public MyLocalDialect() { super(); registerFunction(my_change_local,new SQLFunctionTemplate(,my_change_local(?1))); } } 2.修改配置文件,将数据库方言指向自己定义的方言类 将 =5InnoDBDialect 改为 = 3.之后就可以在hql中使用自己定义的函数了

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐