您好,登錄后才能下訂單哦!
小編給大家分享一下@MapperScan掃描包里混有@Service等問題怎么辦,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
@MapperScan注解配置的一般是dao或者mapper的掃描包,一般用于數據庫操作,里面類的一般都是接口,如果在dao層有其他接口,比如說@Service等就會報錯
把service包移走,方法可行
不使用@MapperScan,在每個dao或者mapper里面加上注解@Mapper,方法可行
使用自定義注解,在mybatis的注解比較完善的情況下,就不用自己搞多少
創建注解@MyMapperScan
里面的屬性全部抄襲@MapperScan
MapperScannerRegistrar換成自己的
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) @Documented @Import(MyMapperScannerRegistrar.class) @Repeatable(MapperScans.class) public @interface MapperScan { String[] value() default {}; String[] basePackages() default {}; Class<?>[] basePackageClasses() default {}; Class<? extends BeanNameGenerator> nameGenerator() default BeanNameGenerator.class; Class<? extends Annotation> annotationClass() default Annotation.class; Class<?> markerInterface() default Class.class; String sqlSessionTemplateRef() default ""; String sqlSessionFactoryRef() default ""; Class<? extends MapperFactoryBean> factoryBean() default MapperFactoryBean.class; String lazyInitialization() default ""; }
MyMapperScannerRegistrar掃描注冊器
這個類和mybatis的一模一樣,唯一的不同就是MyClassPathMapperScanner是自己的掃描
public class MyMapperScannerRegistrar extends MapperScannerRegistrar { private ResourceLoader resourceLoader; /** * {@inheritDoc} */ @Override public void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry) { AnnotationAttributes annoAttrs = AnnotationAttributes.fromMap(importingClassMetadata.getAnnotationAttributes(MapperScan.class.getName())); //這個是自己的 ClassPathMapperScanner scanner = new MyClassPathMapperScanner(registry); // this check is needed in Spring 3.1 if (resourceLoader != null) { scanner.setResourceLoader(resourceLoader); } Class<? extends Annotation> annotationClass = annoAttrs.getClass("annotationClass"); if (!Annotation.class.equals(annotationClass)) { scanner.setAnnotationClass(annotationClass); } Class<?> markerInterface = annoAttrs.getClass("markerInterface"); if (!Class.class.equals(markerInterface)) { scanner.setMarkerInterface(markerInterface); } Class<? extends BeanNameGenerator> generatorClass = annoAttrs.getClass("nameGenerator"); if (!BeanNameGenerator.class.equals(generatorClass)) { scanner.setBeanNameGenerator(BeanUtils.instantiateClass(generatorClass)); } Class<? extends MapperFactoryBean> mapperFactoryBeanClass = annoAttrs.getClass("factoryBean"); if (!MapperFactoryBean.class.equals(mapperFactoryBeanClass)) { scanner.setMapperFactoryBean(BeanUtils.instantiateClass(mapperFactoryBeanClass)); } scanner.setSqlSessionTemplateBeanName(annoAttrs.getString("sqlSessionTemplateRef")); scanner.setSqlSessionFactoryBeanName(annoAttrs.getString("sqlSessionFactoryRef")); List<String> basePackages = new ArrayList<String>(); for (String pkg : annoAttrs.getStringArray("value")) { if (StringUtils.hasText(pkg)) { basePackages.add(pkg); } } for (String pkg : annoAttrs.getStringArray("basePackages")) { if (StringUtils.hasText(pkg)) { basePackages.add(pkg); } } for (Class<?> clazz : annoAttrs.getClassArray("basePackageClasses")) { basePackages.add(ClassUtils.getPackageName(clazz)); } scanner.registerFilters(); scanner.doScan(StringUtils.toStringArray(basePackages)); } /** * {@inheritDoc} */ @Override public void setResourceLoader(ResourceLoader resourceLoader) { this.resourceLoader = resourceLoader; } }
MyClassPathMapperScanner
自己的掃描類基本也是mybatis的,就是在判斷上面改動了一點點
public class MyClassPathMapperScanner extends ClassPathMapperScanner { public MyClassPathMapperScanner(BeanDefinitionRegistry registry) { super(registry); } @Override protected boolean isCandidateComponent(AnnotatedBeanDefinition beanDefinition) { boolean flag = super.isCandidateComponent(beanDefinition); //包名帶有Mapper的才會被mybatis代理 boolean mapper = beanDefinition.getBeanClassName().contains("Mapper"); return flag && mapper; } }
現在只需要用自己的掃描注解即可,用法和mybatis的一模一樣
這個是針對第三點的,作者使用第三點的時候mybatis版本為3.4.6
mybatis-spring版本為1.3.2,spring版本為5.x
當mybatis版本為3.5.2的mybatis-spring版本為2.0.2的時候
MapperScannerRegistrar類掃描的方式發生了一點點變化,
還需要改寫MapperScannerConfigurer類,其他的不變
完畢!
@MapperScan注解使用markerInterface或者annotationClass參數限制掃描的接口
由于不太注意順手就導了spring的包:
import org.mybatis.spring.annotation.MapperScan;
結果就異常:
tk.mybatis.mapper.provider.base.BaseSelectProvider:xxxx
應該導mybatis的MapperScan而不是spring中的包,正確的包名:
import tk.mybatis.spring.annotation.MapperScan;
看完了這篇文章,相信你對“@MapperScan掃描包里混有@Service等問題怎么辦”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。