All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pingcap.tikv.TiBatchWriteUtils Maven / Gradle / Ivy

There is a newer version: 3.2.3
Show newest version
/*
 * Copyright 2019 PingCAP, Inc.
 *
 * 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
 *
 *      http://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,
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.pingcap.tikv;

import com.pingcap.tikv.key.IndexKey;
import com.pingcap.tikv.key.Key;
import com.pingcap.tikv.key.RowKey;
import com.pingcap.tikv.meta.TiIndexInfo;
import com.pingcap.tikv.meta.TiTableInfo;
import com.pingcap.tikv.region.TiRegion;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;
import java.util.stream.Collectors;

public class TiBatchWriteUtils {

  private static final Comparator tiIndexInfoComparator =
      Comparator.comparing(TiIndexInfo::getId);

  public static List getRegionByIndex(
      TiSession session, TiTableInfo table, TiIndexInfo index) {
    ArrayList regionList = new ArrayList<>();
    Key min = IndexKey.toIndexKey(table.getId(), index.getId());
    Key max = min.nextPrefix();

    while (min.compareTo(max) < 0) {
      TiRegion region = session.getRegionManager().getRegionByKey(min.toByteString());
      regionList.add(region);
      min = Key.toRawKey(region.getEndKey());
    }
    return regionList;
  }

  public static List getIndexRegions(TiSession session, TiTableInfo table) {
    return table
        .getIndices()
        .stream()
        .sorted(tiIndexInfoComparator)
        .flatMap(index -> getRegionByIndex(session, table, index).stream())
        .collect(Collectors.toList());
  }

  public static List getRecordRegions(TiSession session, TiTableInfo table) {
    ArrayList regionList = new ArrayList<>();
    Key key = RowKey.createMin(table.getId());
    RowKey endRowKey = RowKey.createBeyondMax(table.getId());

    while (key.compareTo(endRowKey) < 0) {
      TiRegion region = session.getRegionManager().getRegionByKey(key.toByteString());
      regionList.add(region);
      key = Key.toRawKey(region.getEndKey());
    }
    return regionList;
  }

  public static List getRegionsByTable(TiSession session, TiTableInfo table) {
    List recordRegions = getIndexRegions(session, table);
    recordRegions.addAll(getRecordRegions(session, table));
    return recordRegions;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy