batchingbatcher.java
来自「hibernate-3.0.5 中文文档」· Java 代码 · 共 116 行
JAVA
116 行
//$Id: BatchingBatcher.java,v 1.8 2005/05/09 22:12:48 steveebersole Exp $package org.hibernate.jdbc;import java.sql.PreparedStatement;import java.sql.SQLException;import org.hibernate.HibernateException;import org.hibernate.StaleStateException;/** * An implementation of the <tt>Batcher</tt> interface that * actually uses batching * @author Gavin King */public class BatchingBatcher extends AbstractBatcher { private int batchSize; private int[] expectedRowCounts; public BatchingBatcher(ConnectionManager connectionManager) { super( connectionManager ); expectedRowCounts = new int[ getFactory().getSettings().getJdbcBatchSize() ]; } public void addToBatch(int expectedRowCount) throws SQLException, HibernateException { log.trace("Adding to batch"); PreparedStatement batchUpdate = getStatement(); batchUpdate.addBatch(); expectedRowCounts[ batchSize++ ] = expectedRowCount; if ( batchSize==getFactory().getSettings().getJdbcBatchSize() ) { //try { doExecuteBatch(batchUpdate); /*} catch (SQLException sqle) { closeStatement(batchUpdate); throw sqle; } catch (HibernateException he) { closeStatement(batchUpdate); throw he; }*/ } } protected void doExecuteBatch(PreparedStatement ps) throws SQLException, HibernateException { if (batchSize==0) { log.debug("no batched statements to execute"); } else { if ( log.isDebugEnabled() ) log.debug("Executing batch size: " + batchSize ); try { checkRowCounts( ps.executeBatch() ); } catch (RuntimeException re) { log.error("Exception executing batch: ", re); throw re; } finally { batchSize=0; //ps.clearBatch(); } } } private void checkRowCounts(int[] rowCounts) { int rowCountLength = rowCounts.length; if ( rowCountLength!=batchSize ) { log.warn("JDBC driver did not return the expected number of row counts"); } for ( int i=0; i<rowCountLength; i++ ) { checkRowCount( rowCounts[i], expectedRowCounts[i], i ); } } private void checkRowCount(int rowCount, int expectedRowCount, int i) { if ( rowCount==-2 ) { if ( log.isDebugEnabled() ) log.debug("success of batch update unknown: " + i); } else if ( rowCount==-3 ) { throw new HibernateException("Batch update failed: " + i); } else { if ( expectedRowCount>=0 ) { if ( rowCount<expectedRowCount ) { throw new StaleStateException( "Batch update returned unexpected row count from update: " + i + " actual row count: " + rowCount + " expected: " + expectedRowCount ); } if ( rowCount>expectedRowCount ) { throw new HibernateException( "Batch update returned unexpected row count from update: " + i + " actual row count: " + rowCount + " expected: " + expectedRowCount ); } } } }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?