关于springboot:netsfjsqlparserparserParseException-Encountered-unexpected

原文地址

写在后面

最近开发过程中,在where条件中应用IF函数,在MySQL数据库中,应用Navicat运行没有问题,然而运行我的项目的时候,死活过不去,始终报错,起初一番折腾找到了解决方案,所以,以防后续再呈现相似问题,仅做记录!

阐明:我的项目为SpringBoot我的项目,长久化层框架应用的是Mybatis-plus(版本为3.0.7)

1.问题复现

1.1 SQL语句执行后果

1.2 Mapper层对应接口

1.3 Mabyties对应xml

1.4 报错信息

2. 问题起因

  针对这个问题,在网上查了相干文档,Mybatis-plus官网说是框架中应用到了多租户性能,Mybatis-plus 会 进行数据权限的过滤,然而有些接口,其实并不想被多租户过滤,所以要对该条sql,进行租户放行。对于这块Mybatis-plus官网阐明了 SqlParserFilter sql 解析过滤器,当然对这部分感兴趣的小伙伴们,能够去Mybatis-plus官网查看相干源码,我这里就不在具体阐明了。

阐明:多租户:多个用户间应用同一套程序,但每个用户之间实现数据隔离

3.问题解决

参考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.4.0以下版本能够间接 增加此注解 即可,3.1.1以下版本须要增加如下配置:

# 开启 SQL 解析缓存注解失效
mybatis-plus:
  global-config:
    sql-parser-cache: true

mybatis-plus3.4.0及以上版本留神:
@SqlParser(filter = true) 在mybatis-plus最新版本3.4.0及以上版本中被标记为已过期,具体代替计划,官网已给出

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE, ElementType.METHOD})
public @interface InterceptorIgnore {
    ...
}

对于此注解官网给出如下应用办法:

鉴于此,如果我的项目引入的MybatisPlus版本为3.4.0及以上,则多租户屏蔽某个特定mapper接口的办法,则应用如下解决方案:

@InterceptorIgnore(tenantLine = "true")
List<EmpWhiteList> getAdminList(@Param("empId") String empId, @Param("timeDate") String timeDate);

【腾讯云】轻量 2核2G4M,首年65元

阿里云限时活动-云数据库 RDS MySQL  1核2G配置 1.88/月 速抢

本文由乐趣区整理发布,转载请注明出处,谢谢。

您可能还喜欢...

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据