Class CriterionRenderer
- java.lang.Object
-
- org.mybatis.dynamic.sql.where.render.CriterionRenderer
-
- All Implemented Interfaces:
SqlCriterionVisitor<Optional<RenderedCriterion>>
public class CriterionRenderer extends Object implements SqlCriterionVisitor<Optional<RenderedCriterion>>
Renders aSqlCriterion
to aRenderedCriterion
. The process is complex because all conditions may or may not be a candidate for rendering. For example, "isEqualWhenPresent" will not render when the value is null. It is also complex because SqlCriterion may or may not include sub-criteria.Rendering is a recursive process. The renderer will recurse into each sub-criteria - which may also contain further sub-criteria - until all possible sub-criteria are rendered into a single fragment. So, for example, the fragment may end up looking like:
col1 = ? and (col2 = ? or (col3 = ? and col4 = ?))
It is also possible that the end result will be empty if all criteria and sub-criteria are not valid for rendering.
- Author:
- Jeff Butler
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
CriterionRenderer.Builder
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Optional<RenderedCriterion>
render(List<AndOrCriteriaGroup> subCriteria, Function<FragmentCollector,String> fragmentCalculator)
Optional<RenderedCriterion>
render(SqlCriterion initialCriterion, List<AndOrCriteriaGroup> subCriteria, Function<FragmentCollector,String> fragmentCalculator)
<T> Optional<RenderedCriterion>
visit(ColumnAndConditionCriterion<T> criterion)
Optional<RenderedCriterion>
visit(CriteriaGroup criterion)
Optional<RenderedCriterion>
visit(ExistsCriterion criterion)
Optional<RenderedCriterion>
visit(NotCriterion criterion)
-
-
-
Method Detail
-
visit
public <T> Optional<RenderedCriterion> visit(ColumnAndConditionCriterion<T> criterion)
- Specified by:
visit
in interfaceSqlCriterionVisitor<Optional<RenderedCriterion>>
-
visit
public Optional<RenderedCriterion> visit(ExistsCriterion criterion)
- Specified by:
visit
in interfaceSqlCriterionVisitor<Optional<RenderedCriterion>>
-
visit
public Optional<RenderedCriterion> visit(CriteriaGroup criterion)
- Specified by:
visit
in interfaceSqlCriterionVisitor<Optional<RenderedCriterion>>
-
visit
public Optional<RenderedCriterion> visit(NotCriterion criterion)
- Specified by:
visit
in interfaceSqlCriterionVisitor<Optional<RenderedCriterion>>
-
render
public Optional<RenderedCriterion> render(SqlCriterion initialCriterion, List<AndOrCriteriaGroup> subCriteria, Function<FragmentCollector,String> fragmentCalculator)
-
render
public Optional<RenderedCriterion> render(List<AndOrCriteriaGroup> subCriteria, Function<FragmentCollector,String> fragmentCalculator)
-
-