在自己已有的项目中
导入依赖:
<dependency>
<groupId>org.apache.shardingsphere</groupId>
<artifactId>sharding-jdbc-spring-boot-starter</artifactId>
<version>4.0.0-RC1</version>
</dependency>
在application.yml文件中增加数据源的配置
spring:
shardingsphere:
datasource:
names:
#数据库的名称master,slave是可以随意定义的,但是要跟下面一致
master,slave
# 主数据源
master:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.220.128:3306/rw?characterEncoding=utf-8
username: root
password: root
# 从数据源
slave:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.220.130:3306/rw?characterEncoding=utf-8
username: root
password: root
masterslave:
# 读写分离配置
load-balance-algorithm-type: round_robin #轮询 ,如果有多个从库,从库的负载均衡策略
# 最终的数据源名称
name: dataSource
# 主库数据源名称
master-data-source-name: master #主库对应的数据源名称 谁是主库,谁是从路是这里配置的,跟上面的数据源名称无关
# 从库数据源名称列表,多个逗号分隔
slave-data-source-names: slave #从库对应的数据源名称
props:
sql:
show: true #开启SQL显示,默认false
main:
allow-bean-definition-overriding: true #该配置项的目的,是如果当前项目中存在同名的bean,后定义的bean会覆盖先定义的
测试:
看查询和其他增删改的区别
select
update