org.mybatis.dynamic.sql.select.render.SearchedCaseRenderer 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.render;
import java.util.Objects;
import java.util.Optional;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import org.mybatis.dynamic.sql.BasicColumn;
import org.mybatis.dynamic.sql.exception.InvalidSqlException;
import org.mybatis.dynamic.sql.render.RenderingContext;
import org.mybatis.dynamic.sql.select.caseexpression.SearchedCaseModel;
import org.mybatis.dynamic.sql.select.caseexpression.SearchedCaseWhenCondition;
import org.mybatis.dynamic.sql.util.FragmentAndParameters;
import org.mybatis.dynamic.sql.util.FragmentCollector;
import org.mybatis.dynamic.sql.util.Messages;
public class SearchedCaseRenderer {
private final SearchedCaseModel searchedCaseModel;
private final RenderingContext renderingContext;
public SearchedCaseRenderer(SearchedCaseModel searchedCaseModel, RenderingContext renderingContext) {
this.searchedCaseModel = Objects.requireNonNull(searchedCaseModel);
this.renderingContext = Objects.requireNonNull(renderingContext);
}
public FragmentAndParameters render() {
FragmentCollector fc = new FragmentCollector();
fc.add(renderCase());
fc.add(renderWhenConditions());
renderElse().ifPresent(fc::add);
fc.add(renderEnd());
return fc.toFragmentAndParameters(Collectors.joining(" ")); //$NON-NLS-1$
}
private FragmentAndParameters renderCase() {
return FragmentAndParameters.fromFragment("case"); //$NON-NLS-1$
}
private FragmentAndParameters renderWhenConditions() {
return searchedCaseModel.whenConditions().map(this::renderWhenCondition)
.collect(FragmentCollector.collect())
.toFragmentAndParameters(Collectors.joining(" ")); //$NON-NLS-1$
}
private FragmentAndParameters renderWhenCondition(SearchedCaseWhenCondition whenCondition) {
return Stream.of(renderWhen(whenCondition), renderThen(whenCondition)).collect(FragmentCollector.collect())
.toFragmentAndParameters(Collectors.joining(" ")); //$NON-NLS-1$
}
private FragmentAndParameters renderWhen(SearchedCaseWhenCondition whenCondition) {
SearchedCaseWhenConditionRenderer renderer = new SearchedCaseWhenConditionRenderer.Builder(whenCondition)
.withRenderingContext(renderingContext)
.build();
return renderer.render()
.orElseThrow(() -> new InvalidSqlException(Messages.getString("ERROR.39"))); //$NON-NLS-1$
}
private FragmentAndParameters renderThen(SearchedCaseWhenCondition whenCondition) {
return whenCondition.thenValue().render(renderingContext).mapFragment(f -> "then " + f);
}
private Optional renderElse() {
return searchedCaseModel.elseValue().map(this::renderElse);
}
private FragmentAndParameters renderElse(BasicColumn elseValue) {
return elseValue.render(renderingContext).mapFragment(f -> "else " + f); //$NON-NLS-1$
}
private FragmentAndParameters renderEnd() {
return FragmentAndParameters.fromFragment("end"); //$NON-NLS-1$
}
}