bboss持久層設置數據庫查詢fetchsize參數方法
jdbc驅動程序api提供了指定了查詢語句fetchsize的方法,有些數據庫(好比oracle)自己提供了fetchsize的默認值,這樣進行大量數據查詢時,不會由於返回的結果集太大致使jvm爆掉,有些數據庫可能沒有默認設置fetchsize,所以須要手動指定。bboss持久層設置數據庫查詢fetchsize參數方法很簡單,只要在poolman.xml文件的datasource中指定一個queryfetchsize參數便可,若是不指定就採用數據庫驅動提供的默認值。
設置queryfetchsize的示例:
mysql
<datasource> 數據庫
<dbname>bspf</dbname> api
<loadmetadata>false</loadmetadata> oracle
<enablejta>true</enablejta> jvm
<jndiName>druid_datasource_jndiname</jndiName> fetch
<datasourceFile>dbcp.xml</datasourceFile> ui
<autoprimarykey>false</autoprimarykey> url
<showsql>true</showsql> spa
<keygenerate>composite</keygenerate>
<queryfetchsize>10000</queryfetchsize>
</datasource>
queryfetchsize爲0或小於0,或者不設置就採用數據庫驅動提供的fetchsize默認值。
mysql數據庫比較特殊,須要在jdbc鏈接串中添加參數useCursorFetch=true纔會起做用,例如:
jdbc:mysql://localhost:3306/bboss?useCursorFetch=true
<property name="datasource" class="com.frameworkset.commons.dbcp2.BasicDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/bboss?useCursorFetch=true"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
<!--initialSize: 初始化鏈接-->
<property name="initialSize" value="5"/>
<property name="maxTotal" value="20"/>
<!--maxIdle: 最大空閒鏈接-->
<property name="maxIdle" value="20"/>
<!--minIdle: 最小空閒鏈接-->
<property name="minIdle" value="20"/>
<!--removeAbandoned: 是否自動回收超時鏈接-->
<property name="removeAbandonedOnBorrow" value="false"/>
<property name="logAbandoned" value="true"/>
<!--removeAbandonedTimeout: 超時時間(以秒數爲單位)-->
<property name="removeAbandonedTimeout" value="180"/>
<!--maxWait: 超時等待時間以毫秒爲單位 6000毫秒/1000等於6秒-->
<property name="maxWaitMillis" value="3000"/>
<property name="validationQuery" value="select 1"/>
<property name="testOnBorrow" value="true"/>
</property>