package liquibase.statement.core; import java.util.LinkedList; import java.util.List; import liquibase.statement.AbstractSqlStatement; import liquibase.statement.core.InsertStatement; public class InsertSetStatement extends AbstractSqlStatement { private LinkedList<InsertStatement> inserts = new LinkedList<InsertStatement>(); private String catalogName; private String schemaName; private String tableName; private int batchSize; public InsertSetStatement(String catalogName, String schemaName, String tableName) { this(catalogName, schemaName, tableName, 50); } public InsertSetStatement(String catalogName, String schemaName, String tableName,int batchSize) { this.catalogName = catalogName; this.schemaName = schemaName; this.tableName = tableName; this.batchSize = batchSize; } public String getCatalogName() { return catalogName; } public String getSchemaName() { return schemaName; } public String getTableName() { return tableName; } public int getBatchThreshold() { return batchSize; } public InsertSetStatement addInsertStatement(InsertStatement statement) { /* if(statement.getCatalogName() != this.getCatalogName() || statement.getShemaName() != this.getSchemaName() || statement.getTableName() != this.getTableName()) { // HANDLE ERROR CONDITION }*/ inserts.add(statement); return this; } public InsertStatement peek() { return inserts.peek(); } public List<InsertStatement> getStatements() { return inserts; } public InsertStatement[] getStatementsArray() { return inserts.toArray(new InsertStatement[0]); } }