栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

数据库分库分表(六)shardingjdbc垂直分库+水平分库+水平分表demo

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

数据库分库分表(六)shardingjdbc垂直分库+水平分库+水平分表demo

即有多个数据库,每个数据库有不同的表,如在前面订单按年分库按月分表的基建上,还有一个user库存放t_user表:

1、代码:

server.context-path=/sharding
server.port=6666
mybatis.mapper-locations=classpath*:Mapper/*Mapper.xml

#配置dbcp的数据池,这里只配置必须字段
my.pool.url=jdbc:mysql://localhost:3306/sharding-demo?useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadonly=false
my.pool.username =root
my.pool.password=******
my.pool.driverClassName =com.mysql.jdbc.Driver

# 配置数据源
spring.shardingsphere.datasource.names=sharding_demo_2020,sharding_demo_2021,dbu0
#配置sharding_demo_2020
spring.shardingsphere.datasource.sharding_demo_2020.type= com.alibaba.druid.pool.DruidDataSource
spring.shardingsphere.datasource.sharding_demo_2020.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.sharding_demo_2020.url=jdbc:mysql://localhost:3306/sharding_demo_2020?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.shardingsphere.datasource.sharding_demo_2020.username=root
spring.shardingsphere.datasource.sharding_demo_2020.password=******
#配置sharding_demo_2021
spring.shardingsphere.datasource.sharding_demo_2021.type= com.alibaba.druid.pool.DruidDataSource
spring.shardingsphere.datasource.sharding_demo_2021.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.sharding_demo_2021.url=jdbc:mysql://localhost:3306/sharding_demo_2021?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.shardingsphere.datasource.sharding_demo_2021.username=root
spring.shardingsphere.datasource.sharding_demo_2021.password=******
#配置dbu0
spring.shardingsphere.datasource.dbu0.type= com.alibaba.druid.pool.DruidDataSource
spring.shardingsphere.datasource.dbu0.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.dbu0.url=jdbc:mysql://localhost:3306/sharding_demo_user?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.shardingsphere.datasource.dbu0.username=root
spring.shardingsphere.datasource.dbu0.password=******
# 打开sql输出日志
spring.shardingsphere.props.sql.show=true

#配置t_order库、表的分布,配置主键id为雪花算法自增长
spring.shardingsphere.sharding.tables.t_order.actual-data-nodes=sharding_demo_$->{2020..2021}.t_order_$->{1..12}
spring.shardingsphere.sharding.tables.t_order.key-generator.column=id
spring.shardingsphere.sharding.tables.t_order.key-generator.type=SNOWFLAKE
#配置t_order表的分库策略,按年分库
spring.shardingsphere.sharding.tables.t_order.database-strategy.standard.preciseAlgorithmClassName=com.demo.config.OrderDbPreciseShardingConfig
spring.shardingsphere.sharding.tables.t_order.database-strategy.standard.rangeAlgorithmClassName=com.demo.config.OrderDbRangeShardingConfig
spring.shardingsphere.sharding.tables.t_order.database-strategy.standard.sharding-column=order_date
#配置t_order表的分表策略,按月分表
spring.shardingsphere.sharding.tables.t_order.table-strategy.standard.preciseAlgorithmClassName=com.demo.config.OrderTablePreciseShardingConfig
spring.shardingsphere.sharding.tables.t_order.table-strategy.standard.rangeAlgorithmClassName=com.demo.config.OrderTableRangeShardingConfig
spring.shardingsphere.sharding.tables.t_order.table-strategy.standard.sharding-column=order_date

#配置垂直分库t_user的策略
spring.shardingsphere.sharding.tables.t_user.actual-data-nodes=dbu0.t_user
spring.shardingsphere.sharding.tables.t_user.key-generator.column=id
spring.shardingsphere.sharding.tables.t_user.key-generator.type=SNOWFLAKE
spring.shardingsphere.sharding.tables.t_user.table-strategy.inline.sharding-column=id
#由于只有一张表,因此在此直接写表明,不需要像水平分多个表那样写策略
spring.shardingsphere.sharding.tables.t_user.table-strategy.inline.algorithm-expression=t_user

2、测试:

(1)新增用户:


        insert into t_user(user_name,age) values (#{userName},#{age})
    
2021-12-23 14:31:33.405  INFO 10476 --- [nio-6666-exec-1] ShardingSphere-SQL                       : Actual SQL: dbu0 ::: insert into t_user (user_name, age, id) VALUES (?, ?, ?) ::: [张三1, 1, 680783745912930305]

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/678005.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号