# 多租户功能
- - -
## 版本 >= 5.X
## 前置说明(重要)
1. 本框架多租户功能的实现是基于 [MyBatis-Plus 多租户插件](https://baomidou.com/pages/aef2f2/#tenantlineinnerinterceptor) 的,只支持最简单的隔离。
2. 本系统默认开启多租户功能。
3. 多租户业务表建表需要加上租户id `tenant_id`,可参考其他系统表。
4. 非多租户表可在配置文件进行配置排除。
5. 只有超级管理员支持切换租户。
## 多租户使用流程(先说结论再展开!)
0. 开启多租户配置(系统默认已经开启)
1. 登录界面(可以选择不同租户)
> 注:如果为租户设置了绑定域名,则只能选择当前域名相关的租户列表。
2. 设置多租户套餐
3. 新增/修改租户(需要选择套餐)
4. 切换租户(仅超级管理员可操作)
## 多租户配置
`application.yml`
> 开关 `enable` 节点不用废话。
> 如果不需要过滤租户的表可在 `excludes` 节点下添加。
**注意: 如果已经基于租户模式启动了程序 关闭租户必须删除mysql与redis内的相关数据重新导入sql**

## 忽略租户
1.如果需要指定单独 SQL 不开启过滤,可在对应的 Mapper 接口添加如下忽略注解:
```
@InterceptorIgnore(tenantLine = "true", dataPermission = "false")
```
**此处注意事项 使用此注解如果需要开启数据权限 dataPermission = "false" 必须添加 mp的注解默认是忽略数据权限的 会导致数据权限失效**
2.如果需要在业务层忽略多租户,可调用以下方法(推荐使用):
```
# 无返回值
TenantHelper.ignore(() -> { 业务代码 });
# 有返回值
Class result = TenantHelper.ignore(() -> { return 业务代码 });
```
## 动态切换租户
**仅适用于特殊需求业务(例如: 创建租户时, 对该租户操作一些数据, 或者需要去其他租户查一些数据等) 禁止乱用后果自负**
```
# 无返回值
TenantHelper.dynamic(租户id, () -> { 业务代码 });
# 有返回值
Class result = TenantHelper.dynamic(租户id, () -> { return 业务代码 });
```
## 登录界面

> 注:如果为租户设置了绑定域名,则只能选择当前域名相关的租户列表。
## 租户套餐管理
### 租户套餐新增


> 注:
> 1、先新增套餐再新增租户,因为租户新增之后无法修改所选套餐。
> 2、租户所关联的套餐如果后续有修改可以进行同步。
## 租户管理
### 默认租户
> 注:默认租户无法修改

### 新增租户
#### 填写表单

#### 选择新增的租户套餐

#### 新增完成

#### 登录租户


### 修改租户
#### 配置域名


#### 没有配置域名

#### 强调一下:这不是bug!
> 注:域名的配置就是为了绑定特定租户!
### 同步套餐
应用场景:租户套餐进行了修改,配置的菜单需要同步到特定租户。
(不是所有租户都有更新套餐的权利, 这是跟钱挂钩的)
> 点一下按钮的事,图略。
## 切换租户(仅超级管理员)
> 注:管理员切换租户不是切换用户,切换的只是数据,管理员拥有所有权限。


