日期 版本 作者 说明
2022-2-26 V-1.0 孔留锋 文档创建。

概要

简介

​ 基于RuoYi-Vue 3.8.1,Mybatis-Plus适配,同时配置多数据源。

整改

主项目POM文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

<properties>
<mybatisplus.version>3.4.1</mybatisplus.version>
<mybatisplus.dynamic.version>2.5.7</mybatisplus.dynamic.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>dynamic-datasource-spring-boot-starter</artifactId>
<version>${mybatisplus.dynamic.version}</version>
</dependency>
</dependencies>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>${mybatisplus.version}</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>${mybatisplus.version}</version>
</dependency>
</dependencyManagement>

common模块

pom文件修改

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
<dependencies>
<!-- SpringBoot Web容器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>

<!-- SpringBoot 拦截器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

<!-- mybatis-plus -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
</dependency>

<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>

<!-- 动态数据源 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>dynamic-datasource-spring-boot-starter</artifactId>
</dependency>
</dependencies>
<modules>
<module>common</module>
<module>admin</module>
<module>framework</module>
<module>system</module>
<module>quartz</module>
<module>generator</module>
</modules>

代码修改

BaseEntity.class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
public class SysUser extends BaseEntity
{
private static final long serialVersionUID = 1L;

/** 用户ID */
@Excel(name = "用户序号", cellType = ColumnType.NUMERIC, prompt = "用户编号")
@TableId(type= IdType.AUTO)
private Long userId;

/** 部门ID */
@Excel(name = "部门编号", type = Type.IMPORT)
private Long deptId;

/** 用户账号 */
@Excel(name = "登录名称")
private String userName;

/** 用户昵称 */
@Excel(name = "用户名称")
private String nickName;

/** 用户邮箱 */
@Excel(name = "用户邮箱")
private String email;

/** 手机号码 */
@Excel(name = "手机号码")
private String phonenumber;

/** 用户性别 */
@Excel(name = "用户性别", readConverterExp = "0=男,1=女,2=未知")
private String sex;

/** 用户头像 */
private String avatar;

/** 密码 */
private String password;

/** 帐号状态(0正常 1停用) */
@Excel(name = "帐号状态", readConverterExp = "0=正常,1=停用")
private String status;

/** 删除标志(0代表存在 2代表删除) */
private String delFlag;

/** 最后登录IP */
@Excel(name = "最后登录IP", type = Type.EXPORT)
private String loginIp;

/** 最后登录时间 */
@Excel(name = "最后登录时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss", type = Type.EXPORT)
private Date loginDate;

/** 部门对象 */
@Excels({
@Excel(name = "部门名称", targetAttr = "deptName", type = Type.EXPORT),
@Excel(name = "部门负责人", targetAttr = "leader", type = Type.EXPORT)
})
@TableField(exist = false)
private SysDept dept;

/** 角色对象 */
@TableField(exist = false)
private List<SysRole> roles;

/** 角色组 */
@TableField(exist = false)
private Long[] roleIds;

/** 岗位组 */
@TableField(exist = false)
private Long[] postIds;

/** 角色ID */
@TableField(exist = false)
private Long roleId;

private String createBy;
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date createTime;
private String updateBy;
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date updateTime;

public SysUser()
{

}

@Override
public String getCreateBy() {
return createBy;
}

@Override
public void setCreateBy(String createBy) {
this.createBy = createBy;
}

@Override
public Date getCreateTime() {
return createTime;
}

@Override
public void setCreateTime(Date createTime) {
this.createTime = createTime;
}

@Override
public String getUpdateBy() {
return updateBy;
}

@Override
public void setUpdateBy(String updateBy) {
this.updateBy = updateBy;
}

@Override
public Date getUpdateTime() {
return updateTime;
}

@Override
public void setUpdateTime(Date updateTime) {
this.updateTime = updateTime;
}

public SysUser(Long userId)
{
this.userId = userId;
}

public Long getUserId()
{
return userId;
}

public void setUserId(Long userId)
{
this.userId = userId;
}

public boolean isAdmin()
{
return isAdmin(this.userId);
}

public static boolean isAdmin(Long userId)
{
return userId != null && 1L == userId;
}

public Long getDeptId()
{
return deptId;
}

public void setDeptId(Long deptId)
{
this.deptId = deptId;
}

@Xss(message = "用户昵称不能包含脚本字符")
@Size(min = 0, max = 30, message = "用户昵称长度不能超过30个字符")
public String getNickName()
{
return nickName;
}

public void setNickName(String nickName)
{
this.nickName = nickName;
}

@Xss(message = "用户账号不能包含脚本字符")
@NotBlank(message = "用户账号不能为空")
@Size(min = 0, max = 30, message = "用户账号长度不能超过30个字符")
public String getUserName()
{
return userName;
}

public void setUserName(String userName)
{
this.userName = userName;
}

@Email(message = "邮箱格式不正确")
@Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符")
public String getEmail()
{
return email;
}

public void setEmail(String email)
{
this.email = email;
}

@Size(min = 0, max = 11, message = "手机号码长度不能超过11个字符")
public String getPhonenumber()
{
return phonenumber;
}

public void setPhonenumber(String phonenumber)
{
this.phonenumber = phonenumber;
}

public String getSex()
{
return sex;
}

public void setSex(String sex)
{
this.sex = sex;
}

public String getAvatar()
{
return avatar;
}

public void setAvatar(String avatar)
{
this.avatar = avatar;
}

public String getPassword()
{
return password;
}

public void setPassword(String password)
{
this.password = password;
}

public String getStatus()
{
return status;
}

public void setStatus(String status)
{
this.status = status;
}

public String getDelFlag()
{
return delFlag;
}

public void setDelFlag(String delFlag)
{
this.delFlag = delFlag;
}

public String getLoginIp()
{
return loginIp;
}

public void setLoginIp(String loginIp)
{
this.loginIp = loginIp;
}

public Date getLoginDate()
{
return loginDate;
}

public void setLoginDate(Date loginDate)
{
this.loginDate = loginDate;
}

public SysDept getDept()
{
return dept;
}

public void setDept(SysDept dept)
{
this.dept = dept;
}

public List<SysRole> getRoles()
{
return roles;
}

public void setRoles(List<SysRole> roles)
{
this.roles = roles;
}

public Long[] getRoleIds()
{
return roleIds;
}

public void setRoleIds(Long[] roleIds)
{
this.roleIds = roleIds;
}

public Long[] getPostIds()
{
return postIds;
}

public void setPostIds(Long[] postIds)
{
this.postIds = postIds;
}

public Long getRoleId()
{
return roleId;
}

public void setRoleId(Long roleId)
{
this.roleId = roleId;
}

@Override
public String toString() {
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)
.append("userId", getUserId())
.append("deptId", getDeptId())
.append("userName", getUserName())
.append("nickName", getNickName())
.append("email", getEmail())
.append("phonenumber", getPhonenumber())
.append("sex", getSex())
.append("avatar", getAvatar())
.append("password", getPassword())
.append("status", getStatus())
.append("delFlag", getDelFlag())
.append("loginIp", getLoginIp())
.append("loginDate", getLoginDate())
.append("createBy", getCreateBy())
.append("createTime", getCreateTime())
.append("updateBy", getUpdateBy())
.append("updateTime", getUpdateTime())
.append("remark", getRemark())
.append("dept", getDept())
.toString();
}
}

SysUser.class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
    }

public void setUserId(Long userId)
{
this.userId = userId;
}

public boolean isAdmin()
{
return isAdmin(this.userId);
}

public static boolean isAdmin(Long userId)
{
return userId != null && 1L == userId;
}

public Long getDeptId()
{
return deptId;
}

public void setDeptId(Long deptId)
{
this.deptId = deptId;
}

@Xss(message = "用户昵称不能包含脚本字符")
@Size(min = 0, max = 30, message = "用户昵称长度不能超过30个字符")
public String getNickName()
{
return nickName;
}

public void setNickName(String nickName)
{
this.nickName = nickName;
}

@Xss(message = "用户账号不能包含脚本字符")
@NotBlank(message = "用户账号不能为空")
@Size(min = 0, max = 30, message = "用户账号长度不能超过30个字符")
public String getUserName()
{
return userName;
}

public void setUserName(String userName)
{
this.userName = userName;
}

@Email(message = "邮箱格式不正确")
@Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符")
public String getEmail()
{
return email;
}

public void setEmail(String email)
{
this.email = email;
}

@Size(min = 0, max = 11, message = "手机号码长度不能超过11个字符")
public String getPhonenumber()
{
return phonenumber;
}

public void setPhonenumber(String phonenumber)
{
this.phonenumber = phonenumber;
}

public String getSex()
{
return sex;
}

public void setSex(String sex)
{
this.sex = sex;
}

public String getAvatar()
{
return avatar;
}

public void setAvatar(String avatar)
{
this.avatar = avatar;
}

public String getPassword()
{
return password;
}

public void setPassword(String password)
{
this.password = password;
}

public String getStatus()
{
return status;
}

public void setStatus(String status)
{
this.status = status;
}

public String getDelFlag()
{
return delFlag;
}

public void setDelFlag(String delFlag)
{
this.delFlag = delFlag;
}

public String getLoginIp()
{
return loginIp;
}

public void setLoginIp(String loginIp)
{
this.loginIp = loginIp;
}

public Date getLoginDate()
{
return loginDate;
}

public void setLoginDate(Date loginDate)
{
this.loginDate = loginDate;
}

public SysDept getDept()
{
return dept;
}

public void setDept(SysDept dept)
{
this.dept = dept;
}

public List<SysRole> getRoles()
{
return roles;
}

public void setRoles(List<SysRole> roles)
{
this.roles = roles;
}

public Long[] getRoleIds()
{
return roleIds;
}

public void setRoleIds(Long[] roleIds)
{
this.roleIds = roleIds;
}

public Long[] getPostIds()
{
return postIds;
}

public void setPostIds(Long[] postIds)
{
this.postIds = postIds;
}

public Long getRoleId()
{
return roleId;
}

public void setRoleId(Long roleId)
{
this.roleId = roleId;
}

@Override
public String toString() {
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)
.append("userId", getUserId())
.append("deptId", getDeptId())
.append("userName", getUserName())
.append("nickName", getNickName())
.append("email", getEmail())
.append("phonenumber", getPhonenumber())
.append("sex", getSex())
.append("avatar", getAvatar())
.append("password", getPassword())
.append("status", getStatus())
.append("delFlag", getDelFlag())
.append("loginIp", getLoginIp())
.append("loginDate", getLoginDate())
.append("createBy", getCreateBy())
.append("createTime", getCreateTime())
.append("updateBy", getUpdateBy())
.append("updateTime", getUpdateTime())
.append("remark", getRemark())
.append("dept", getDept())
.toString();
}
}

BaseEntity.class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
public class TreeEntity extends BaseEntity
{
private static final long serialVersionUID = 1L;

/** 父菜单名称 */
@TableField(exist =false)
private String parentName;

/** 父菜单ID */
@TableField(exist =false)
private Long parentId;

/** 显示顺序 */
@TableField(exist =false)
private Integer orderNum;

/** 祖级列表 */
@TableField(exist =false)
private String ancestors;

/** 子部门 */
@TableField(exist =false)
private List<?> children = new ArrayList<>();

public String getParentName()
{
return parentName;
}

public void setParentName(String parentName)
{
this.parentName = parentName;
}

public Long getParentId()
{
return parentId;
}

public void setParentId(Long parentId)
{
this.parentId = parentId;
}

public Integer getOrderNum()
{
return orderNum;
}

public void setOrderNum(Integer orderNum)
{
this.orderNum = orderNum;
}

public String getAncestors()
{
return ancestors;
}

public void setAncestors(String ancestors)
{
this.ancestors = ancestors;
}

public List<?> getChildren()
{
return children;
}

public void setChildren(List<?> children)
{
this.children = children;
}
}

核心配置调整

去除DruidProperties.class

1
2
//@Configuration
public class DruidProperties

去除DruidConfig.class

1
2
//@Configuration
public class DruidConfig

去除MyBatisConfig.class

1
2
3
//去除掉,整合mybatis-plus
//@Configuration
public class c

新增MybatisPlusConfig.class

包com.zzsn.common.config 下新增。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package com.zzsn.common.config;

@EnableTransactionManagement(proxyTargetClass = true)
@Configuration
public class MybatisPlusConfig {

@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor()
{
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
// 分页插件
interceptor.addInnerInterceptor(paginationInnerInterceptor());
// 乐观锁插件
interceptor.addInnerInterceptor(optimisticLockerInnerInterceptor());
// 阻断插件
interceptor.addInnerInterceptor(blockAttackInnerInterceptor());
return interceptor;
}

/**
* 分页插件,自动识别数据库类型 https://baomidou.com/guide/interceptor-pagination.html
*/
public PaginationInnerInterceptor paginationInnerInterceptor()
{
PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
// 设置数据库类型为mysql
paginationInnerInterceptor.setDbType(DbType.MYSQL);
// 设置最大单页限制数量,默认 500 条,-1 不受限制
paginationInnerInterceptor.setMaxLimit(-1L);
return paginationInnerInterceptor;
}
/**
* 乐观锁插件 https://baomidou.com/guide/interceptor-optimistic-locker.html
*/
public OptimisticLockerInnerInterceptor optimisticLockerInnerInterceptor()
{
return new OptimisticLockerInnerInterceptor();
}

/**
* 如果是对全表的删除或更新操作,就会终止该操作 https://baomidou.com/guide/interceptor-block-attack.html
*/
public BlockAttackInnerInterceptor blockAttackInnerInterceptor()
{
return new BlockAttackInnerInterceptor();
}
}

system模块

实现mybaits-plus 对ISysUserService支撑,其他类改造雷同。

代码修改

ISysUserService.class

1
public interface ISysUserService extends IService<SysUser>

SysUserServiceImpl.class

1
public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser> implements ISysUserService

SysUserMapper.class

1
public interface SysUserMapper extends BaseMapper<SysUser>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#mysql多数据源配置
spring:
autoconfigure:
exclude: com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure
datasource:
dynamic:
druid:
# 初始连接数
initialSize: 5
# 最小连接池数量
minIdle: 10
# 最大连接池数量
maxActive: 20
# 配置获取连接等待超时的时间
maxWait: 60000
# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
timeBetweenEvictionRunsMillis: 60000
# 配置一个连接在池中最小生存的时间,单位是毫秒
minEvictableIdleTimeMillis: 300000
# 配置一个连接在池中最大生存的时间,单位是毫秒
maxEvictableIdleTimeMillis: 900000
# 配置检测连接是否有效
validationQuery: SELECT 1 FROM DUAL
testWhileIdle: true
testOnBorrow: false
testOnReturn: false
webStatFilter:
enabled: true
filter:
stat:
enabled: true
# 慢SQL记录
log-slow-sql: true
slow-sql-millis: 1000
merge-sql: true
wall:
config:
multi-statement-allow: true
primary: master
datasource:
master:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://192.168.10.1:3306/core_data_base?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8&rewriteBatchedStatements=true
username: root
password: '@123456.'
slave:
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://192.168.10.1:3306/sentiment_data_base?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8&rewriteBatchedStatements=true
username: root
password: '@123456.'
#整合mybatis-plus
mybatis-plus:
typeAliasesPackage: com.zzsn.**.domain
mapperLocations: classpath*:mapper/**/*Mapper.xml
configLocation: classpath:mybatis/mybatis-config.xml