日期:2014-05-16  浏览次数:20474 次

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中,这样可以进一步提高持久层的开发效率。