View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements.  See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache License, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License.  You may obtain a copy of the License at
8    *
9    *     http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  
18  package org.apache.shardingsphere.data.pipeline.core.consistencycheck.table;
19  
20  import lombok.Getter;
21  import lombok.RequiredArgsConstructor;
22  import org.apache.shardingsphere.data.pipeline.core.consistencycheck.ConsistencyCheckJobItemProgressContext;
23  import org.apache.shardingsphere.data.pipeline.core.datasource.PipelineDataSource;
24  import org.apache.shardingsphere.data.pipeline.core.metadata.model.PipelineColumnMetaData;
25  import org.apache.shardingsphere.data.pipeline.core.ratelimit.JobRateLimitAlgorithm;
26  import org.apache.shardingsphere.infra.metadata.database.schema.QualifiedTable;
27  
28  import java.util.List;
29  
30  /**
31   * Table inventory check parameter.
32   */
33  @RequiredArgsConstructor
34  @Getter
35  public final class TableInventoryCheckParameter {
36      
37      private final String jobId;
38      
39      private final int splittingItem;
40      
41      private final PipelineDataSource sourceDataSource;
42      
43      private final PipelineDataSource targetDataSource;
44      
45      private final QualifiedTable sourceTable;
46      
47      private final QualifiedTable targetTable;
48      
49      private final List<String> columnNames;
50      
51      private final List<PipelineColumnMetaData> uniqueKeys;
52      
53      private final JobRateLimitAlgorithm readRateLimitAlgorithm;
54      
55      private final ConsistencyCheckJobItemProgressContext progressContext;
56      
57      private final String queryCondition;
58      
59      public TableInventoryCheckParameter(final String jobId, final PipelineDataSource sourceDataSource, final PipelineDataSource targetDataSource,
60                                          final QualifiedTable sourceTable, final QualifiedTable targetTable,
61                                          final List<String> columnNames, final List<PipelineColumnMetaData> uniqueKeys,
62                                          final JobRateLimitAlgorithm readRateLimitAlgorithm, final ConsistencyCheckJobItemProgressContext progressContext) {
63          this(jobId, 0, sourceDataSource, targetDataSource, sourceTable, targetTable, columnNames, uniqueKeys, readRateLimitAlgorithm, progressContext,
64                  null);
65      }
66  }