我们有几个计算风控值的定时任务,几乎每隔5秒会更新所有账户的当前总资产并以此通知风控,每隔一小时就产生一两个G的binlog,几十台服务器折腾。。数据库是公用的,代码是通过工具自动生成的,直接修改流程和周期太长了,故最后决定在jdbc连接时设置会话参数。
dbcp:connectionInitSqls set @@session.sql_bin_log = 0,如果多个的话,则使用list格式。如下:
<property name="connectionInitSqls">
<list>
<value>set @@session.sql_bin_log = 0;</value>
<value>set @@session.innodb_flush_log_at_trx_commit = 0;</value>
</list>
</property>
c3p0:暂不支持,这个时候可以通过jdbc.url中的选项设置,比如sessionVariables=key:value,key:value,会被当做SET SESSION执行,这样还可以连接池无关。
除此之外,dbcp还有一个很重要的但是c3p0实现不一样的点是,在某些情况下,我们需要访问datasource的具体实现,比如实现mysql的local into table,此时需要使用mysql的datasource实现,如下所示:
PreparedStatement statement = conn.prepareStatement(loadDataSql);
if (statement.isWrapperFor(com.mysql.jdbc.Statement.class)) {
com.mysql.jdbc.PreparedStatement mysqlStatement = statement.unwrap(com.mysql.jdbc.PreparedStatement.class);
}
因为c3p0实现的unwrap是抽象方法,因此默认情况下无法直接得到底层驱动的PareparedStatement。