Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
iBiz4j Spring R7
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
iBiz-R7后台标准模板
iBiz4j Spring R7
提交
b8f972ad
提交
b8f972ad
编写于
9月 18, 2020
作者:
xignzi006
🇨🇳
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
SaaS配置支持
上级
f5476f80
变更
1
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
41 行增加
和
0 行删除
+41
-0
MybatisConfiguration.java.ftl
...S_PKGPATH%/core/util/config/MybatisConfiguration.java.ftl
+41
-0
未找到文件。
SLN/%PUBPRJ%-core/src/main/java/%SYS_PKGPATH%/core/util/config/MybatisConfiguration.java.ftl
浏览文件 @
b8f972ad
<#
ibiztemplate
>
TARGET
=
PSSYSTEM
</#
ibiztemplate
>
...
...
@@ -16,6 +17,15 @@ import org.springframework.context.annotation.Bean;
import
org
.
springframework
.
context
.
annotation
.
Configuration
;
import
org
.
mybatis
.
spring
.
annotation
.
MapperScan
;
import
java
.
util
.
Properties
;
<#
if
sys
.
getPSSystemSetting
().
getSaaSMode
()==
1
>
import
cn
.
ibizlab
.
resourcescheduling
.
util
.
security
.
AuthenticationUser
;
import
com
.
baomidou
.
mybatisplus
.
extension
.
plugins
.
tenant
.
TenantHandler
;
import
com
.
baomidou
.
mybatisplus
.
extension
.
plugins
.
tenant
.
TenantSqlParser
;
import
net
.
sf
.
jsqlparser
.
expression
.
Expression
;
import
net
.
sf
.
jsqlparser
.
expression
.
StringValue
;
import
java
.
util
.
ArrayList
;
import
java
.
util
.
List
;
</#
if
>
/**
*
mybatis
全局配置类
...
...
@@ -52,6 +62,37 @@ public class MybatisConfiguration {
//
paginationInterceptor
.
setOverflow
(
false
);
//
设置最大单页限制数量,默认
500
条,
-
1
不受限制
paginationInterceptor
.
setLimit
(-
1
);
<#
if
sys
.
getPSSystemSetting
().
getSaaSMode
()==
1
>
//
创建
SQL
解析器集合
List
<
ISqlParser
>
sqlParserList
=
new
ArrayList
<>();
//
创建租户
SQL
解析器
TenantSqlParser
tenantSqlParser
=
new
TenantSqlParser
();
//
设置租户处理器
tenantSqlParser
.
setTenantHandler
(
new
TenantHandler
()
{
@
Override
public
Expression
getTenantId
(
boolean
where
)
{
AuthenticationUser
user
=
AuthenticationUser
.
getAuthenticationUser
();
return
new
StringValue
(
user
.
getDomain
());
}
@
Override
public
String
getTenantIdColumn
()
{
return
"SRFDCID"
;
}
@
Override
public
boolean
doTableFilter
(
String
tableName
)
{
return
false
;
}
});
sqlParserList
.
add
(
tenantSqlParser
);
paginationInterceptor
.
setSqlParserList
(
sqlParserList
);
</#
if
>
//
开启
count
的
join
优化
,
只针对部分
left
join
paginationInterceptor
.
setCountSqlParser
(
new
JsqlParserCountOptimize
(
true
));
return
paginationInterceptor
;
...
...
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录