1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package examples.paging;
17
18 import java.util.HashMap;
19 import java.util.Map;
20 import java.util.Objects;
21 import java.util.function.Function;
22
23 import org.mybatis.dynamic.sql.render.RenderingStrategies;
24 import org.mybatis.dynamic.sql.select.SelectModel;
25 import org.mybatis.dynamic.sql.select.render.SelectStatementProvider;
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43 public class LimitAndOffsetAdapter<R> {
44 private final SelectModel selectModel;
45 private final Function<SelectStatementProvider, R> mapperMethod;
46 private final int limit;
47 private final int offset;
48
49 private LimitAndOffsetAdapter(SelectModel selectModel, Function<SelectStatementProvider, R> mapperMethod,
50 int limit, int offset) {
51 this.selectModel = Objects.requireNonNull(selectModel);
52 this.mapperMethod = Objects.requireNonNull(mapperMethod);
53 this.limit = limit;
54 this.offset = offset;
55 }
56
57 public R execute() {
58 return mapperMethod.apply(selectStatement());
59 }
60
61 private SelectStatementProvider selectStatement() {
62 return new LimitAndOffsetDecorator(
63 selectModel.render(RenderingStrategies.MYBATIS3));
64 }
65
66 public static <R> LimitAndOffsetAdapter<R> of(SelectModel selectModel,
67 Function<SelectStatementProvider, R> mapperMethod, int limit, int offset) {
68 return new LimitAndOffsetAdapter<>(selectModel, mapperMethod, limit, offset);
69 }
70
71 public class LimitAndOffsetDecorator implements SelectStatementProvider {
72 private final Map<String, Object> parameters = new HashMap<>();
73 private final String selectStatement;
74
75 public LimitAndOffsetDecorator(SelectStatementProvider delegate) {
76 parameters.putAll(delegate.getParameters());
77 parameters.put("limit", limit);
78 parameters.put("offset", offset);
79
80 selectStatement = delegate.getSelectStatement() +
81 " LIMIT #{parameters.limit} OFFSET #{parameters.offset}";
82 }
83
84 @Override
85 public Map<String, Object> getParameters() {
86 return parameters;
87 }
88
89 @Override
90 public String getSelectStatement() {
91 return selectStatement;
92 }
93 }
94 }