Oralce预编译Sql语句在JDBC中的处理
一、预编译的SQL语句处理
预编译接口PreparedStatement是java.sql中的一个接口,它是Statement的一个自接口。Statement执行Sql语句时,需要将完整的Sql发送给数据库,数据库经过编译后再执行。预编译的语句和Statement对象不同,在创建PreparedStatement对象时指定了Sql语句,该sql语句立刻发送给数据库进行编译。当编译语句执行时,直接运行编译后的Sql语句,而不像其他Sql语句先经过编译在执行。预编译的SQL语句处理性能稍微高于普通的传递变量的办法。
二、对web项目持久层的封装
通过对Oracle动态参数绑定的理解。使用Oracle占位符:的语句会通过SGA中的共享池来直接对该SQL语句进行缓存,那么在下一次执行类似语句时就直接调用缓存中已解析过的语句,以此来提高执行效率。
现在有很多持久层框架,就我个人喜好,还是喜欢最原始的Sql方式,如果一个程序员不会写Sql那他就不是一个程序员。
针对上面对Sql预编译和Oracle缓存机制的解释,大家似乎也想到了,使用PreparedStatement可以提高Sql的执行效率,但是?占位符并不能缓存到SGA,下次执行该DAO方法还会经过预编译的过程,所以将带有:占位符的Sql做为参数传给PreparedStatement中缓存到SGA中,这样可以进一步提高持久层的开发效率。
相关推荐
技术驱动人生 2020-04-24
mryangjx 2019-11-11
zmjzhangmj 2019-09-17
我是一棵树 2019-04-24
LadyZhong 2019-07-01
沉着前进 2019-06-30
晶莹的代码 2019-06-30
dangzhangjing 2019-06-30
Stephenmu 2012-05-24
helloxiaoliang 2019-06-27
gigipop 2019-06-27
yaodilu 2019-06-27
impress 2019-06-27
MarkArch 2019-06-27
huangzhe0 2011-02-11
陈浩 2019-06-21
步行者 2010-03-20