Sharding Algorithm

    Additionally, considering the complexity of business scenarios, the built-in algorithm also provides a way to customize the sharding algorithm. Users can complete complex sharding logic by writing java code.

    Modulo Sharding Algorithm

    Type: MOD

    Attributes:

    Modulo sharding algorithm provided by CosId

    Modulo sharding algorithm implemented by the tool class based on . See the discussion at .

    Type: COSID_MOD

    Attributes:

    NameDataTypeDescription
    modintSharding count
    logic-name-prefixStringPrefix pattern of sharding data sources or tables

    Hash Modulo Sharding Algorithm

    Type: HASH_MOD

    Attributes:

    NameDataTypeDescription
    sharding-countintSharding count

    Volume Based Range Sharding Algorithm

    Type: VOLUME_RANGE

    Attributes:

    NameDataTypeDescription
    range-lowerlongRange lower bound, throw exception if lower than bound
    range-upperlongRange upper bound, throw exception if upper than bound
    sharding-volumelongSharding volume

    Boundary Based Range Sharding Algorithm

    Attributes:

    Auto Interval Sharding Algorithm

    Type: AUTO_INTERVAL

    Attributes:

    NameDataTypeDescription
    datetime-lowerStringShard datetime begin boundary, pattern: yyyy-MM-dd HH:mm:ss
    datetime-upperStringShard datetime end boundary, pattern: yyyy-MM-dd HH:mm:ss
    sharding-secondslongMax seconds for the data in one shard, allows sharding key timestamp format seconds with time precision, but time precision after seconds is automatically erased

    Apache ShardingSphere built-in standard sharding algorithm are:

    Inline Sharding Algorithm

    With Groovy expressions, InlineShardingStrategy provides single-key support for the sharding operation of = and IN in SQL. Simple sharding algorithms can be used through a simple configuration to avoid laborious Java code developments. For example, t_user_$->{u_id % 8} means table t_user is divided into 8 tables according to u_id, with table names from t_user_0 to t_user_7. Please refer to Inline Expression for more details.

    Type: INLINE

    Attributes:

    NameDataTypeDescriptionDefault Value
    algorithm-expressionStringInline expression sharding algorithm-
    allow-range-query-with-inline-sharding (?)booleanWhether range query is allowed. Note: range query will ignore sharding strategy and conduct full routingfalse

    Interval Sharding Algorithm

    This algorithm actively ignores the time zone information of datetime-pattern. This means that when datetime-lower, datetime-upper and the incoming shard key contain time zone information, time zone conversion will not occur due to time zone inconsistencies. When the incoming sharding key is , there is a special case, which will carry the time zone information of the system and convert it into the string format of datetime-pattern, and then proceed to the next sharding.

    Type: INTERVAL

    Attributes:

    NameDataTypeDescriptionDefault Value
    datetime-patternStringTimestamp pattern of sharding value, must can be transformed to Java LocalDateTime. For example: yyyy-MM-dd HH:mm:ss, yyyy-MM-dd or HH:mm:ss etc. But Gy-MM etc. related to java.time.chrono.JapaneseDate are not supported-
    datetime-lowerStringDatetime sharding lower boundary, pattern is defined datetime-pattern-
    datetime-upper (?)StringDatetime sharding upper boundary, pattern is defined datetime-patternNow
    sharding-suffix-patternStringSuffix pattern of sharding data sources or tables, must can be transformed to Java LocalDateTime, must be consistent with datetime-interval-unit. For example: yyyyMM-
    datetime-interval-amount (?)intInterval of sharding value, after which the next shard will be entered1
    datetime-interval-unit (?)StringUnit of sharding value interval, must can be transformed to Java ChronoUnit’s Enum value. For example: MONTHSDAYS

    Fixed interval sharding algorithm provided by CosId

    Type:COSID_INTERVAL

    Attributes:

    Snowflake key-based fixed interval sharding algorithm provided by CosId

    Snowflake ID sharding algorithm with fixed time range implemented by tool class based on me.ahoo.cosid:cosid-core. When the sharding key is a JSR-310 containing class or a time-related class, it will be converted to java.time.LocalDateTime before the next sharding. See the discussion at https://github.com/apache/shardingsphere/issues/14047.

    Type:COSID_INTERVAL_SNOWFLAKE

    Attributes:

    NameDataTypeDescriptionDefault Value
    zone-idStringTime zone, which must follow the contained value of java.time.ZoneId. For example: Asia/Shanghai
    logic-name-prefixStringPrefix pattern of sharding data sources or tables
    datetime-lowerStringDatetime sharding lower boundary, pattern is consistent with the timestamp format of yyyy-MM-dd HH:mm:ss
    datetime-upperStringDatetime sharding upper boundary, pattern is consistent with the timestamp format of yyyy-MM-dd HH:mm:ss
    sharding-suffix-patternStringSuffix pattern of sharding data sources or tables, must can be transformed to Java LocalDateTime, must be consistent with datetime-interval-unit. For example: yyyyMM
    datetime-interval-unitStringUnit of sharding value interval, must can be transformed to Java ChronoUnit’s Enum value. For example: MONTHS
    datetime-interval-amountintInterval of sharding value, after which the next shard will be entered

    Complex Inline Sharding Algorithm

    Please refer to for more details.

    Type: COMPLEX_INLINE

    NameDataTypeDescriptionDefault Value
    sharding-columns (?)Stringsharing column names-
    algorithm-expressionStringInline expression sharding algorithm-
    allow-range-query-with-inline-sharding (?)booleanWhether range query is allowed. Note: range query will ignore sharding strategy and conduct full routingfalse

    Hint Inline Sharding Algorithm

    Please refer to Inline Expression for more details.

    Type: COMPLEX_INLINE

    NameDataTypeDescriptionDefault Value
    algorithm-expressionStringInline expression sharding algorithm${value}

    Realize custom extension by configuring the sharding strategy type and algorithm class name. CLASS_BASED allows additional custom properties to be passed into the algorithm class. The passed properties can be retrieved through the java.util.Properties class instance with the property name . Refer to Git’s org.apache.shardingsphere.example.extension.sharding.algortihm.classbased.fixture.ClassBasedStandardShardingAlgorithmFixture.

    Attributes:

    1. When using data sharding, configure the corresponding data sharding algorithm under the shardingAlgorithms attribute.