1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.apache.shardingsphere.data.pipeline.core.sqlbuilder.sql;
19
20 import org.apache.shardingsphere.data.pipeline.core.sqlbuilder.dialect.DialectPipelineSQLBuilder;
21 import org.apache.shardingsphere.data.pipeline.core.sqlbuilder.segment.PipelineSQLSegmentBuilder;
22 import org.apache.shardingsphere.database.connector.core.spi.DatabaseTypedSPILoader;
23 import org.apache.shardingsphere.database.connector.core.type.DatabaseType;
24 import org.apache.shardingsphere.infra.metadata.database.schema.QualifiedTable;
25
26 import java.util.Optional;
27
28
29
30
31 public final class PipelineDataConsistencyCalculateSQLBuilder {
32
33 private final DialectPipelineSQLBuilder dialectSQLBuilder;
34
35 private final PipelineSQLSegmentBuilder sqlSegmentBuilder;
36
37 public PipelineDataConsistencyCalculateSQLBuilder(final DatabaseType databaseType) {
38 dialectSQLBuilder = DatabaseTypedSPILoader.getService(DialectPipelineSQLBuilder.class, databaseType);
39 sqlSegmentBuilder = new PipelineSQLSegmentBuilder(databaseType);
40 }
41
42
43
44
45
46
47
48
49 public Optional<String> buildCRC32SQL(final QualifiedTable qualifiedTable, final String columnName) {
50 return dialectSQLBuilder.buildCRC32SQL(
51 sqlSegmentBuilder.getQualifiedTableName(qualifiedTable), sqlSegmentBuilder.getEscapedIdentifier(columnName));
52 }
53 }