org.mybatis.dynamic.sql.select.join.JoinSpecification 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.select.join;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.stream.Stream;
import org.mybatis.dynamic.sql.TableExpression;
import org.mybatis.dynamic.sql.util.Validator;
public class JoinSpecification {
private final TableExpression table;
private final List> joinCriteria;
private final JoinType joinType;
private JoinSpecification(Builder builder) {
table = Objects.requireNonNull(builder.table);
joinCriteria = Objects.requireNonNull(builder.joinCriteria);
joinType = Objects.requireNonNull(builder.joinType);
Validator.assertNotEmpty(joinCriteria, "ERROR.16"); //$NON-NLS-1$
}
public TableExpression table() {
return table;
}
@SuppressWarnings("java:S1452")
public Stream> joinCriteria() {
return joinCriteria.stream();
}
public JoinType joinType() {
return joinType;
}
public static Builder withJoinTable(TableExpression table) {
return new Builder().withJoinTable(table);
}
public static class Builder {
private TableExpression table;
private final List> joinCriteria = new ArrayList<>();
private JoinType joinType;
public Builder withJoinTable(TableExpression table) {
this.table = table;
return this;
}
public Builder withJoinCriterion(JoinCriterion> joinCriterion) {
this.joinCriteria.add(joinCriterion);
return this;
}
public Builder withJoinCriteria(List> joinCriteria) {
this.joinCriteria.addAll(joinCriteria);
return this;
}
public Builder withJoinType(JoinType joinType) {
this.joinType = joinType;
return this;
}
public JoinSpecification build() {
return new JoinSpecification(this);
}
}
}