springBoot + mybatisPlus 多数据源 实现 saas系统
最近在做的his系统是saas模式,使用的医院id作为所有数据的区分条件,这个应该是目前比较好的实现办法了,毕竟好维护,开发也比较方便。
之前在开放的时候突然想到用多数据源实现saas模式试一下。
文章底部有整个demo的代码
saas主库
多数据源实现saas的大概思路是,在一个主数据库里维护一下saas的信息,比如数据库,数据库地址,账号密码什么的
create table saas_main (
id bigint primary key comment '雪花id',
name varchar(16) comment '租户名称',
type int comment '数据库类型',
driver_class_name varchar(256) comment '驱动',
jdbc_url varchar(1024) comment '数据库链接地址',
username varchar(256) comment '数据库账户',
password varchar(256) comment '数据库密码',
data_base varchar(256) comment '数据库'
);
具体业务逻辑数据库
使用多数据源实现不同的数据库对应不同的用户
-- 数据库1
create database saas_1;
use saas_1;
CREATE TABLE `user`
(
`id` int(11) primary key auto_increment,
`name` varchar(255) comment '姓名'
)
-- 数据库2
create database saas_2;
use saas_2;
CREATE TABLE `user`
(
`id` int(11) primary key auto_increment,
`name` varchar(255) comment '姓名'
)
-- 数据库3
create database saas_3;
use saas_3;
CREATE TABLE `user`
(
`id` int(11) primary key auto_increment,
`name` varchar(255) comment '姓名'
)
pom
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.example</groupId>
<artifactId>demo</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.7.0</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.dromara.stream-query</groupId>
<artifactId></