导航:首页 > 编程语言 > java绑定变量

java绑定变量

发布时间:2022-11-15 23:12:59

java数据库中的问号代表什么意思

你说的是写sql时候的?吗 那是占位符的意思。

比如:

占位符方式写sql的好处:

1.增加SQL代码可读性
2.占位符可以预先编译,提高执行效率
3.防止SQL注入
4用占位符的目的是绑定变量,这样可以减少数据SQL的硬解析,所以执行效率会提高不少

② 在java 中写oracle的sql是:insert into A values(,); 然后绑定变量,DB2的sq也有这样写的吗l

db2也可以这么写。。。。。这个其实是通用sql支持的,但是不建议这么做,维护和查看程序逻辑不方便。建议这样写 INSERT INTO 表名(列1,列2,.....) VALUES(?,?,.....)

③ 如何在DELPHI或JAVA实现绑定变量

var s:string;begin s:='declare @MyId varchar(800)' +' set @MyId=''''' +' select top 4 @MyId=@MyId+','+cast(id as varchar(20)) from Mytable' +' select @MyId'; with adoquery1 do begin close; sql.text:=s; open; showmessage(fields[0].asstring);//取值 end;end;

④ jdbc查询数据库报:java.sql.SQLException: ORA-01006: 绑定变量不存在

胡乱猜测一下。

int i = 1;
if(um.getUuid() != null && um.getUuid().trim().length() > 0){
pstmt.setString(i, um.getUuid());
i++;
}

java中所有这种类似数组的东西,都应该是从0开始,而不是从1开始。
所以 int i = 0;

⑤ java oracle绑定变量使用问题

PreparedStatement pstmt = con.prepareStatementSELECT QUESTION_ID FROM KM_T_FAQ WHERE XML_ID=? AND UNIQUE_ID LIKE '?'); //注意,这要换写法

pstmt.setString(1, "%_ABCDEFG");//这里面的ABCDEFG,传的参数

⑥ 预编译sql语句就sql绑定变量吗

1. 认识绑定变量:

绑定变量是为了减少解析的,比如你有个语句这样
select aaa,bbb from ccc where ddd=eee;
如果经常通过改变eee这个谓词赋值来查询,像如下
select aaa,bbb from ccc where ddd=fff;
select aaa,bbb from ccc where ddd=ggg;
select aaa,bbb from ccc where ddd=hhh;
每条语句都要被数据库解析一次,这样比较浪费资源,如果把eee换成“:1”这样的绑定变量形式,无论ddd后面是什么值,都不需要重复解析

Java实现绑定变量的方法:
[java] view plain
PreparedStatement pstmt = con.prepareStatement("UPDATE employees SET salay = ? WHERE id = ?");
pstmt.setBigDecimal(1, 15.00);
pstmt.setInt(2, 110592);
/result statmement: UPDATE employees SET salay = 15.00 WHERE id = 110592
pstmt.executeQuery();

假设要将id从1到10000的员工的工资都更新为150.00元,不使用绑定变量,则:
[java] view plain
sql.executeQuery("UPDATE employees SET salay = 150.00 WHERE id = 1");
sql.executeQuery("UPDATE employees SET salay = 150.00 WHERE id = 2");
sql.executeQuery("UPDATE employees SET salay = 150.00 WHERE id = 3");
sql.executeQuery("UPDATE employees SET salay = 150.00 WHERE id = 4");
....
sql.executeQuery("UPDATE employees SET salay = 150.00 WHERE id = 10000");
使用绑定变量,则:
[java] view plain
PreparedStatement pstmt;
for (id = 1; id < 10000; id )
{
if (null == pstmt)
pstmt = con.prepareStatement("UPDATE employees SET salay = ? WHERE id = ?");
pstmt.setBigDecimal(1, 150.00);
pstmt.setInt(2, id);
pstmt.executeQuery();
}
二者区别在于,不用绑定变量,则相当于反复解析、执行了1w个sql语句。使用绑定变量,解析sql语句只用了一次,之后的9999次复用第一次生成的执行计划。显然,后者效率会更高一些。
2. 什么时候不应该/不必要使用绑定变量
a. 如果你用数据仓库,一条大查询一跑几个小时,根本没必要做绑定变量,因为解析的消耗微乎其微。
b. 变量对优化器产生执行计划有很重要的影响的时候:绑定变量被使用时,查询优化器会忽略其具体值,因此其预估的准确性远不如使用字面量值真实,尤其是在表存在数据倾斜(表上的数据非均匀分布)的列上会提供错误的执行计划。从而使得非高效的执行计划被使用。

3. 绑定变量在OceanBase中的实现

前OceanBase中实现了绑定变量,目的主要是为了编程方便,而不是为了降低生成执行计划的代价。为什么呢?因为OceanBase中目前使用的是一
种”静态执行计划“,无论什么Query,执行流程都一样。OB在前端代理ObConnector中实现绑定变量,将用户传入的变量进行
to_string()操作,替代SQL语句中相应的部分,形成一个完整的SQL。然后这个SQL传递给MS,MS按照标准流程来解析和执行。相信不远的
将来,OB将会实现真正意义上的绑定变量,让用户享受到绑定变量带来的好处。

⑦ jdbc查询数据库报:java.sql.SQLException: ORA-01006: 绑定变量不存在

setSqlValue方法为什么返回是void呢,你试试看把传入的pstmt返回回去,在主函数处接收返回的pstmt,就解决了!

⑧ java为啥使用 preparestatement麻烦告诉我

其中分析分为硬分析(Hard Parse)和软分析(Soft Parse)。一条SQL语句通过语法检查后,Oracle 会先去shared pool 中找是否有相同的sql,如果找着了,就叫软分析,然后执行SQL语句。硬分析主要是检查该sql所涉及到的所有对象是否有效以及权限等关系,然后根据RBO或CBO模式生成执行计划,然后才执行SQL语句。可以看出,硬分析比软分析多了很多动作,而这里面的关键是“在shared pool 中是否有相同的sql”,而这就取决于是否使用绑定变量。另:oracle9i引入了soft soft parse,先到pga中的session cursor cache list列表中去查找(session cursor cache list的长度是由session_cache_cursor参数决定的),如果没有找到这条sql,这时候才去检查shard_pool.对于Oltp系统,很多时候硬分析的代价比执行还要高,这个我们可以通过10046事件跟踪得知。(2)共享池中SQL语句数量太多,重用性极低,加速了SQL语句的老化,导致共享池碎片过多。共享池中不同的SQL语句数量巨大,根据LRU原则,一些语句逐渐老化,最终被清理出共享池;这样就导致shared_pool_size 里面命中率下降,共享池碎片增多,可用内存空间不足。而为了维护共享池内部结构,需要使用latch,一种内部生命周期很短的lock,这将使用大量的cpu 资源,使得性能急剧下降。不使用绑定变量违背了oracle 的shared pool 的设计的原则,违背了这个设计用来共享的思想。2、怎么查看没有使用绑定变量select * from v$sql or v$sqlarea 查看是否有很多类似的语句,除了变量不一样,其他的都一样3、如何使用绑定变量?编写java 程序时,我们习惯都是定义JAVA 的程序变量,放入SQL 语句中,如String v_id = 'xxxxx';String v_sql = 'select name from table_a where id = ' + v_id ; 以上代码,看起来是使用了变量v_id ,但这却是java 的程序变量,而不是oracle 的绑定变量,语句传递到数据库后,此java 的程序变量已经被替换成具体的常量值,变成:select * from table_a where name = 'xxxxx' ;假定这个语句第一次执行,会进行硬分析。后来,同一段java 代码中v_id 值发现变化(v_id = 'yyyyyy'),数据库又接收到这样的语句:select * from table_a where name = 'yyyyyy' ;ORACLE 并不认为以上两条语句是相同的语句,因此对第二条语句会又做一次硬分析。这两条语句的执行计划可是一样的!其实,只需将以上java 代码改成以下这样,就使用了oracle 的绑定变量:String v_id = 'xxxxx';String v_sql = 'select name from table_a where id = ? '; //嵌入绑定变量stmt = con.prepareStatement( v_sql );stmt.setString(1, v_id ); //为绑定变量赋值stmt.executeQuery();在Java中,结合使用setXXX 系列方法,可以为不同数据类型的绑定变量进行赋值,从而大大优化了SQL 语句的性能。4、java中应用绑定变量的例子PreparedStatement stmt = conn.prepareStatement('select a from b where c = ? ');stmt.setLong(1,123);stmt.executeQuery()……结论:绑定变量主要适用在Oltp,运行时间很短的系统。如客服系统,时时地进行insert方面的系统。数据仓库系统不适用,和数据库仓库系统的一条sql运行时间相比,硬分析的代价显然是微不足道的,通过硬分析去选择正确的执行计划才是关键。

⑨ 谁能给一个java 写好的解析普通SQL语句 为绑定变量形式java 不胜感谢

你啥意思啊?不咋明白? 你的意思是不是根据sql语句中占位符"?"号的个数和你传进来的参数(像"aaa"、24),给你拼凑好sql语句啊?
也就是说pstm.setString(1,"aaa");pstm.setint(2,24);这样类似的操作由某个程序自动帮你完成吗?

⑩ java.sql.SQLException: ORA-01006: 绑定变量不存在

你system("SELECT name FROM Test WHERE FID="+paras[2]+" FOR UPDATE")这个出来,看下你拼接的,跟你测试的,是不是一摸一样。然后把system出来的这句,复制过去,看能执行不,肯定有拼接错误的,仔细看下

阅读全文

与java绑定变量相关的资料

热点内容
php基础编程教程pdf 浏览:215
穿越之命令与征服将军 浏览:351
android广播重复 浏览:832
像阿里云一样的服务器 浏览:318
水冷空调有压缩机吗 浏览:478
访问日本服务器可以做什么 浏览:432
bytejava详解 浏览:448
androidjava7 浏览:384
服务器在山洞里为什么还有油 浏览:885
天天基金app在哪里下载 浏览:974
服务器软路由怎么做 浏览:291
冰箱压缩机出口 浏览:227
OPT最佳页面置换算法 浏览:644
网盘忘记解压码怎么办 浏览:852
文件加密看不到里面的内容 浏览:653
程序员脑子里都想什么 浏览:434
oppp手机信任app在哪里设置 浏览:189
java地址重定向 浏览:272
一年级下册摘苹果的算法是怎样的 浏览:448
程序员出轨电视剧 浏览:90