Release notes

  • Spring Boot : V2.3.12. RELEASE
  • ShardingSpheref : 5.0.0 – alpha
  • MySql : 5.6

pom

< the dependency > < groupId > mysql < / groupId > < artifactId > mysql connector - Java < / artifactId > < version > 5.1.41 was < / version > </dependency> <dependency> <groupId>org.apache.shardingsphere</groupId> < artifactId > shardingsphere - JDBC - core - spring - the boot - starter < / artifactId > < version > 5.0.0 - alpha < / version > < / dependency >Copy the code

application.properties

# configuration data source spring. Shardingsphere. The datasource. Names = ds0, ds1 spring.shardingsphere.datasource.common.type=com.zaxxer.hikari.HikariDataSource spring.shardingsphere.datasource.common.driver-class-name=com.mysql.jdbc.Driver spring.shardingsphere.datasource.common.username=root spring.shardingsphere.datasource.common.password=123456 Spring. Shardingsphere. The datasource. The ds0. JDBC - url = JDBC: mysql: / / 127.0.0.1:3306 / ds0? ServerTimezone = UTC&useSSL = false Spring. Shardingsphere. The datasource. Ds1. JDBC - url = JDBC: mysql: / / 127.0.0.1:3306 / ds1? ServerTimezone = UTC&useSSL = false # configuration T_order table rules spring. Shardingsphere. Rules. Sharding. Name t_order. Actual data - nodes = ds $- > {0.. 1}.t_order_$->{0.. 1} # configuration depots strategy spring. Shardingsphere. Rules. Sharding. Name t_order. Database - strategy. Standard. Sharding - column = user_id spring.shardingsphere.rules.sharding.tables.t_order.database-strategy.standard.sharding-algorithm-name=database-inline # Spring configuration table strategy. Shardingsphere. Rules. Sharding. Name t_order. Table - strategy. Standard. Sharding - column = order_id Spring. Shardingsphere. Rules. Sharding. Name t_order. Table - strategy. Standard, sharding algorithm - name = # table - the inline configuration Subdivision algorithm spring. Shardingsphere. Rules. Sharding. Sharding - algorithms. The database - the inline. Type = the inline spring.shardingsphere.rules.sharding.sharding-algorithms.database-inline.props.algorithm-expression=ds$->{user_id % 2} spring.shardingsphere.rules.sharding.sharding-algorithms.table-inline.type=INLINE spring.shardingsphere.rules.sharding.sharding-algorithms.table-inline.props.algorithm-expression=t_order_$->{order_id % 2} # distributed sequence policy configuration spring. Shardingsphere. Rules. Sharding. Name t_order. Key - generate - strategy. The column = order_id Spring. Shardingsphere. Rules. Sharding. Name t_order. Key - generate - strategy. The key generator - name = # snowflake distributed configuration sequence algorithm spring.shardingsphere.rules.sharding.key-generators.snowflake.type=SNOWFLAKE Spring. Shardingsphere. Rules. Sharding. Key - generators. Snowflake. Props. The worker - id = 123 # print SQL log spring.shardingsphere.props.sql-show=trueCopy the code
  • Database 1: DS0

    • Table 1: t_order_0
    • Table 2: t_order_1
  • Database 2: DS1

    • Table 1: t_order_0
    • Table 2: t_order_1

  • In the above configuration, DS represents the database name and T_order represents the table name

  • The database is divided by user_id

  • The table sorting strategy is based on order_id

  • Snowflake stands for using the snowflake algorithm

  • Add, delete, modify and check the code unchanged, ShardingSpheref will automatically operate according to the configuration