bboss持久層設置數據庫查詢fetchsize參數方法

bboss持久層設置數據庫查詢fetchsize參數方法 

jdbc驅動程序api提供了指定了查詢語句fetchsize的方法,有些數據庫(好比oracle)自己提供了fetchsize的默認值,這樣進行大量數據查詢時,不會由於返回的結果集太大致使jvm爆掉,有些數據庫可能沒有默認設置fetchsize,所以須要手動指定。bboss持久層設置數據庫查詢fetchsize參數方法很簡單,只要在poolman.xml文件的datasource中指定一個queryfetchsize參數便可,若是不指定就採用數據庫驅動提供的默認值。 

設置queryfetchsize的示例: 
mysql

Xml代碼  收藏代碼sql

  1. <datasource>  數據庫

  2.   

  3.         <dbname>bspf</dbname>  api

  4.         <loadmetadata>false</loadmetadata>  oracle

  5.         <enablejta>true</enablejta>  jvm

  6.         <jndiName>druid_datasource_jndiname</jndiName>  fetch

  7.         <datasourceFile>dbcp.xml</datasourceFile>  ui

  8.         <autoprimarykey>false</autoprimarykey>  url

  9.         <showsql>true</showsql>  spa

  10.         <keygenerate>composite</keygenerate>  

  11.         <queryfetchsize>10000</queryfetchsize>    

  12. </datasource>  



queryfetchsize爲0或小於0,或者不設置就採用數據庫驅動提供的fetchsize默認值。 

mysql數據庫比較特殊,須要在jdbc鏈接串中添加參數useCursorFetch=true纔會起做用,例如: 
jdbc:mysql://localhost:3306/bboss?useCursorFetch=true 

Xml代碼  收藏代碼

  1. <property name="datasource" class="com.frameworkset.commons.dbcp2.BasicDataSource">  

  2.         <property name="driverClassName" value="com.mysql.jdbc.Driver"/>  

  3.         <property name="url" value="jdbc:mysql://localhost:3306/bboss?useCursorFetch=true"/>  

  4.         <property name="username" value="root"/>  

  5.         <property name="password" value="123456"/>  

  6.         <!--initialSize: 初始化鏈接-->  

  7.         <property name="initialSize" value="5"/>  

  8.         <property name="maxTotal" value="20"/>  

  9.         <!--maxIdle: 最大空閒鏈接-->  

  10.         <property name="maxIdle" value="20"/>  

  11.         <!--minIdle: 最小空閒鏈接-->  

  12.         <property name="minIdle" value="20"/>  

  13.   

  14.         <!--removeAbandoned: 是否自動回收超時鏈接-->  

  15.         <property name="removeAbandonedOnBorrow" value="false"/>  

  16.         <property name="logAbandoned" value="true"/>  

  17.         <!--removeAbandonedTimeout: 超時時間(以秒數爲單位)-->  

  18.         <property name="removeAbandonedTimeout" value="180"/>  

  19.         <!--maxWait: 超時等待時間以毫秒爲單位 6000毫秒/1000等於6秒-->  

  20.         <property name="maxWaitMillis" value="3000"/>  

  21.         <property name="validationQuery" value="select 1"/>  

  22.         <property name="testOnBorrow" value="true"/>  

  23. </property>  

相關文章
相關標籤/搜索