背景
项目中有些需要初始化的配置项,希望通过mybatis-plus批量(因为自己比较懒,不想通过循环的方式存储进去[也有点太low])的保存进数据库,但是此时得到的以下的错误
com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: Error: Cannot execute table Method, ClassGenricType not found .
at com.baomidou.mybatisplus.core.toolkit.ExceptionUtils.mpe(ExceptionUtils.java:49)
at com.baomidou.mybatisplus.core.toolkit.Assert.isTrue(Assert.java:38)
at com.baomidou.mybatisplus.core.toolkit.Assert.notNull(Assert.java:72)
at com.baomidou.mybatisplus.extension.toolkit.SqlHelper.table(SqlHelper.java:86)
at com.baomidou.mybatisplus.extension.service.impl.ServiceImpl.sqlStatement(ServiceImpl.java:113)
at com.baomidou.mybatisplus.extension.service.impl.ServiceImpl.saveBatch(ServiceImpl.java:126)
at com.baomidou.mybatisplus.extension.service.IService.saveBatch(IService.java:69)
at com.baomidou.mybatisplus.extension.service.IService$$FastClassBySpringCGLIB$$f8525d18.invoke(<generated>)
at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218)
at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:750)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163)
at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:295)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:98)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:689)
at com.aimsphm.nuclear.ext.service.impl.CommonDeviceDetailsServiceExtImpl$$EnhancerBySpringCGLIB$$5fae3a80.saveBatch(<generated>)
at com.aimsphm.nuclear.core.service.impl.MonitoringServiceImpl.initDefaultConfig(MonitoringServiceImpl.java:214)
at com.aimsphm.nuclear.core.service.impl.MonitoringServiceImpl.modifyDeviceStatus(MonitoringServiceImpl.java:166)
at com.aimsphm.nuclear.core.service.impl.MonitoringServiceImpl$$FastClassBySpringCGLIB$$178697ab.invoke(<generated>)
at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218)
at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:750)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163)
at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:295)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:98)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:689)
at com.aimsphm.nuclear.core.service.impl.MonitoringServiceImpl$$EnhancerBySpringCGLIB$$9006bdbe.modifyDeviceStatus(<generated>)
at com.aimsphm.nuclear.core.controller.MonitoringController.modifyDeviceStatus(MonitoringController.java:74)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:190)
at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:138)
at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:105)
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:893)
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:798)
at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1040)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:943)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1006)
at org.springframework.web.servlet.FrameworkServlet.doPut(FrameworkServlet.java:920)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:663)
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:883)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at com.github.xiaoymin.knife4j.spring.filter.ProductionSecurityFilter.doFilter(ProductionSecurityFilter.java:53)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at com.github.xiaoymin.knife4j.spring.filter.SecurityBasicAuthFilter.doFilter(SecurityBasicAuthFilter.java:90)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:201)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:119)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:367)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:860)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1598)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)
跟着异常栈发现
该对象在这个位置实例化
以下是项目中部分类的结构,很显然我要使用的扩展类的父类中是没有泛型的,因此问提出现这个位置
//服务接口
public interface CommonUserService extends IService<CommonUserDO> {
}
//扩展服务接口
public interface CommonUserServiceExt extends CommonUserService {
}
//实现类
public class CommonUserServiceImpl extends ServiceImpl<CommonUserMapper, CommonUserDO> implements CommonUserService {
}
//实现扩展类
@Service
@ConditionalOnProperty(prefix = "spring.config", name = "enableServiceExtImpl", havingValue = "true")
public class CommonUserServiceExtImpl extends CommonUserServiceImpl implements CommonUserServiceExt {
}
修改如下-确保可执行的service能找到父类的泛型
PS:主要是通过泛型中的实体类,获取到要操作表格的名称
//服务接口
public interface CommonUserService extends IService<CommonUserDO> {
}
//扩展服务接口
public interface CommonUserServiceExt extends CommonUserService {
}
//实现类
public class CommonUserServiceImpl<M extends BaseMapper<T>, T> extends ServiceImpl<CommonUserMapper, CommonUserDO> implements CommonUserService {
}
//实现扩展类
@Service
@ConditionalOnProperty(prefix = "spring.config", name = "enableServiceExtImpl", havingValue = "true")
public class CommonUserServiceExtImpl extends CommonUserServiceImpl<CommonUserMapper, CommonUserDO> implements CommonUserServiceExt {
}
PS :并不是所有的服务都需要扩展服务,如果是直接继承ServiceImpl<M extends BaseMapper<T>, T>,并指定泛型,是可以进行批量操作的
其实日志中已经给出提示,不过此时并不会影响到单个函数的操作[后续有可能MP会修复这个问题(因为可以通过父类的父类泛型获取该实体对象)]
2020-12-16 20:04:46.126 [main] INFO org.springframework.web.context.ContextLoader - Root WebApplicationContext: initialization completed in 3344 ms
2020-12-16 20:04:46.291 [main] WARN com.baomidou.mybatisplus.core.toolkit.ReflectionKit - Warn: CommonComponentServiceExtImpl's superclass not ParameterizedType
2020-12-16 20:04:52.237 [main] WARN com.baomidou.mybatisplus.core.toolkit.ReflectionKit - Warn: CommonDeviceServiceExtImpl's superclass not ParameterizedType
2020-12-16 20:04:52.425 [main] WARN com.baomidou.mybatisplus.core.toolkit.ReflectionKit - Warn: CommonSubSystemServiceExtImpl's superclass not ParameterizedType
2020-12-16 20:04:52.625 [main] WARN com.baomidou.mybatisplus.core.toolkit.ReflectionKit - Warn: CommonMeasurePointServiceExtImpl's superclass not ParameterizedType
2020-12-16 20:04:53.396 [main] INFO org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor - Initializing ExecutorService
2020-12-16 20:04:53.528 [main] WARN com.baomidou.mybatisplus.core.toolkit.ReflectionKit - Warn: CommonBookServiceExtImpl's superclass not ParameterizedType
2020-12-16 20:04:53.588 [main] WARN com.baomidou.mybatisplus.core.toolkit.ReflectionKit - Warn: CommonUserServiceExtImpl's superclass not ParameterizedType
2020-12-16 20:04:53.617 [main] WARN com.baomidou.mybatisplus.core.toolkit.ReflectionKit - Warn: CommonStoreServiceExtImpl's superclass not ParameterizedType
2020-12-16 20:04:53.740 [main] WARN com.baomidou.mybatisplus.core.toolkit.ReflectionKit - Warn: CommonStudentServiceExtImpl's superclass not ParameterizedType