欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

记处理spring-devtools 和 通用mapper 使用问题

程序员文章站 2022-03-25 20:59:56
问题: tk.mybatis.mapper.MapperException: 无法获取实体类com.*.* 对应的表名 环境: springboot 2.0.6, 通用mapper 2.0.4,还有 spring-devtools 描述一下: 这个环境我之前在用,也用的好好的,并没有出问题。 解决: ......

问题:

  tk.mybatis.mapper.mapperexception: 无法获取实体类com.*.* 对应的表名

环境:

  springboot 2.0.6, 通用mapper 2.0.4,还有 spring-devtools 

描述一下:

  这个环境我之前在用,也用的好好的,并没有出问题。

解决:

  问题出来了还是中文异常(通用mapper 抛出的异常),习惯性的度娘,其实这个问题我之前遇到过,果真度娘上的大神都说是配置问题(@mapperscan 导入包为import tk.mybatis.spring.annotation.mapperscan;),怎么可能?我还是检查了一下,当然不可能是配置出错了。

  去翻了一下通用mapper的文档,找到问题了:spring boot 中使用 devtools 和 通用mapper 不兼容,作者说问题是因为热部署插件会把项目中classes下的类和jar包下的类分开加载(restartclassloader ,appclassloader ),通用mapper的entityhelper初始化就读不到相关的实体类信息了,之前的版本解决方法就是把mapper的相关jar包通过配置让restartclassloader去加载,我也跟着试了一下,发现并不行。继续看文档。。。然后看到作者写道:“如果你真遇到这个问题,最直接的方法就是禁用 devtools 工具。”........不可能算了,热部署在开发中这么方便,丢了实在可惜,想想作者发现的问题就是类不是同一种方式加载的,那上面的配置应该是正确的思路,别人怎么就能解决呢。

  看着看着就有了新发现:我这里mapper加载到的实体类和接口有的是其他项目中写的,然后通过本地jar导入当前项目的 和 时说的情况差不多。那就把这些实体类接口通过配置让restartclassloader去加载(spring-devtools.properties):

restart.include.mapper=/mapper-[\\w-\\.]+jar,/mycorp-[\\w-\\.]+jar

启动测试....  妈蛋,还是这个错。想想mapper作者说过:“最合理的情况就是没有 spring-devtools.properties 配置文件”。那就是不用把通用mapper相关包加进去:

restart.include.mapper=/mycorp-[\\w-\\.]+jar

理论上这样才合理(这样也行,那应该时我上面的配置用“,”隔开是错的。。):

restart.include.mapper=/mapper-[\\w-\\.]+jar
restart.include.myname=/mycorp-[\\w-\\.]+jar

这样把我自己的实体类和接口包使用restartclassloader去加载,启动测试.... 竟然可以了


问题估计就是通用mapper需要扫描的接口和对应的实体类没有扫描到而已,所以要用热部署和通用mapper的话就检查一下所使用的mapper接口和实体类有没有可能不在
restartclassloader中加载

 

参考:spring devtools 介绍