org.mybatis.dynamic.sql.insert.render.BatchInsert Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mybatis-dynamic-sql Show documentation
Show all versions of mybatis-dynamic-sql Show documentation
MyBatis framework for generating dynamic SQL
The newest version!
/*
* Copyright 2016-2024 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
*
* https://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 java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;
public class BatchInsert {
private final String insertStatement;
private final List records;
private BatchInsert(Builder builder) {
insertStatement = Objects.requireNonNull(builder.insertStatement);
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 row) {
return DefaultInsertStatementProvider.withRow(row)
.withInsertStatement(insertStatement)
.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 insertStatement;
}
public List getRecords() {
return Collections.unmodifiableList(records);
}
public static Builder withRecords(List records) {
return new Builder().withRecords(records);
}
public static class Builder {
private String insertStatement;
private final List records = new ArrayList<>();
public Builder withInsertStatement(String insertStatement) {
this.insertStatement = insertStatement;
return this;
}
public Builder withRecords(List records) {
this.records.addAll(records);
return this;
}
public BatchInsert build() {
return new BatchInsert<>(this);
}
}
}