时间:2021-07-01 10:21:17 帮助过:43人阅读
针对这个问题,在网上查了相关文档,Mybatis-plus官网说是框架中使用到了多租户功能,Mybatis-plus 会 进行数据权限的过滤,但是有些接口,其实并不想被多租户过滤,所以要对该条sql,进行租户放行。关于这块Mybatis-plus官网说明了 SqlParserFilter
sql 解析过滤器,当然对这部分感兴趣的小伙伴们,可以去Mybatis-plus官网查看相关源码,我这里就不在具体说明了。
说明:多租户:多个用户间使用同一套程序,但每个用户之间实现数据隔离
参考Mybatis-plus官网,在Mapper层接口方法上 加入注解
@SqlParser(filter=true)
官网截图如下:
加完注解之后的Mapper层接口方法如下:
@SqlParser(filter = true) List<EmpWhiteList> getAdminList(@Param("empId") String empId, @Param("timeDate") String timeDate);
加完次注解之后,由于项目的Mybatis-plus版本为3.0.7,所以这里还要再在application.yml文件中添加下列配置才能生效
说明:如果Mybatis-plus版本是3.1.1以上的 直接 添加此注解 即可,3.1.1以下版本需要添加如下配置:
# 开启 SQL 解析缓存注解生效
mybatis-plus:
global-config:
sql-parser-cache: true
参考文档:
1、https://blog.csdn.net/drose29/article/details/103893228
2、https://blog.csdn.net/qq_39313596/article/details/100943090
3、https://mp.baomidou.com/guide/tenant.html
SpringBoot项目:net.sf.jsqlparser.parser.ParseException: Encountered unexpected token:XXXXX
标签:@param 问题解决 目的 ken lan exce app detail EDA