org.mybatis.dynamic.sql.insert.render.BatchInsert Maven / Gradle / Ivy
/**
* Copyright 2016-2018 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.mybatis.dynamic.sql.insert.render;
import static org.mybatis.dynamic.sql.util.StringUtilities.spaceBefore;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;
public class BatchInsert {
private String tableName;
private String columnsPhrase;
private String valuesPhrase;
private List records;
private BatchInsert(Builder builder) {
tableName = Objects.requireNonNull(builder.tableName);
columnsPhrase = Objects.requireNonNull(builder.columnsPhrase);
valuesPhrase = Objects.requireNonNull(builder.valuesPhrase);
records = Collections.unmodifiableList(Objects.requireNonNull(builder.records));
}
/**
* Returns a list of InsertStatement objects. This is useful for MyBatis batch support.
*
* @return a List of InsertStatements
*/
public List> insertStatements() {
return records.stream()
.map(this::toInsertStatement)
.collect(Collectors.toList());
}
private InsertStatementProvider toInsertStatement(T record) {
return DefaultInsertStatementProvider.withRecord(record)
.withTableName(tableName)
.withColumnsPhrase(columnsPhrase)
.withValuesPhrase(valuesPhrase)
.build();
}
/**
* Returns the generated SQL for this batch. This is useful for Spring JDBC batch support.
*
* @return the generated INSERT statement
*/
public String getInsertStatementSQL() {
return "insert into" //$NON-NLS-1$
+ spaceBefore(tableName)
+ spaceBefore(columnsPhrase)
+ spaceBefore(valuesPhrase);
}
public static Builder withRecords(List records) {
return new Builder().withRecords(records);
}
public static class Builder {
private String tableName;
private String columnsPhrase;
private String valuesPhrase;
private List records = new ArrayList<>();
public Builder withTableName(String tableName) {
this.tableName = tableName;
return this;
}
public Builder withColumnsPhrase(String columnsPhrase) {
this.columnsPhrase = columnsPhrase;
return this;
}
public Builder withValuesPhrase(String valuesPhrase) {
this.valuesPhrase = valuesPhrase;
return this;
}
public Builder withRecords(List records) {
this.records.addAll(records);
return this;
}
public BatchInsert build() {
return new BatchInsert<>(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy