@MapperScan掃描包里混有@Service等問(wèn)題如何解決
@MapperScan掃描包混有@Service
問(wèn)題描述
@MapperScan注解配置的一般是dao或者mapper的掃描包,一般用于數(shù)據(jù)庫(kù)操作,里面類的一般都是接口,如果在dao層有其他接口,比如說(shuō)@Service等就會(huì)報(bào)錯(cuò)

解決辦法一
把service包移走,方法可行
解決辦法二
不使用@MapperScan,在每個(gè)dao或者mapper里面加上注解@Mapper,方法可行
解決辦法三
使用自定義注解,在mybatis的注解比較完善的情況下,就不用自己搞多少
創(chuàng)建注解@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掃描注冊(cè)器
這個(gè)類和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()));
//這個(gè)是自己的
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的,就是在判斷上面改動(dòng)了一點(diǎn)點(diǎn)
public class MyClassPathMapperScanner extends ClassPathMapperScanner {
public MyClassPathMapperScanner(BeanDefinitionRegistry registry) {
super(registry);
}
@Override
protected boolean isCandidateComponent(AnnotatedBeanDefinition beanDefinition) {
boolean flag = super.isCandidateComponent(beanDefinition);
//包名帶有Mapper的才會(huì)被mybatis代理
boolean mapper = beanDefinition.getBeanClassName().contains("Mapper");
return flag && mapper;
}
}
現(xiàn)在只需要用自己的掃描注解即可,用法和mybatis的一模一樣
解決辦法四
這個(gè)是針對(duì)第三點(diǎn)的,作者使用第三點(diǎn)的時(shí)候mybatis版本為3.4.6
mybatis-spring版本為1.3.2,spring版本為5.x
當(dāng)mybatis版本為3.5.2的mybatis-spring版本為2.0.2的時(shí)候
MapperScannerRegistrar類掃描的方式發(fā)生了一點(diǎn)點(diǎn)變化,
還需要改寫MapperScannerConfigurer類,其他的不變
完畢!
解決辦法五
@MapperScan注解使用markerInterface或者annotationClass參數(shù)限制掃描的接口
@MapperScan包掃描的坑
在使用通用mapper執(zhí)行查詢時(shí)
由于不太注意順手就導(dǎo)了spring的包:
import org.mybatis.spring.annotation.MapperScan;
結(jié)果就異常:
tk.mybatis.mapper.provider.base.BaseSelectProvider:xxxx
找了半天才發(fā)現(xiàn)是包的問(wèn)題
應(yīng)該導(dǎo)mybatis的MapperScan而不是spring中的包,正確的包名:
import tk.mybatis.spring.annotation.MapperScan;
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java來(lái)實(shí)現(xiàn)文本轉(zhuǎn)圖片需求示例
本文主要介紹了Java來(lái)實(shí)現(xiàn)文本轉(zhuǎn)圖片需求示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-04-04
一文帶你掌握J(rèn)ava8中Lambda表達(dá)式 函數(shù)式接口及方法構(gòu)造器數(shù)組的引用
Java 8 (又稱為 jdk 1.8) 是 Java 語(yǔ)言開發(fā)的一個(gè)主要版本。 Oracle 公司于 2014 年 3 月 18 日發(fā)布 Java 8 ,它支持函數(shù)式編程,新的 JavaScript 引擎,新的日期 API,新的Stream API 等2021-10-10
java內(nèi)存管理關(guān)系及內(nèi)存泄露的原理分析
這篇文章主要介紹了java內(nèi)存管理關(guān)系及內(nèi)存泄露的原理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
IntelliJ IDEA 老司機(jī)居然還沒用過(guò) Stream Trace功能(問(wèn)題小結(jié))
很多朋友酷愛Java8 Stream功能,但是在使用過(guò)程中總不是那么順利,下面通過(guò)本文給大家分享idea Stream Trace調(diào)試過(guò)程遇到的問(wèn)題,需要的朋友參考下吧2021-05-05
Java中反射reflect的基礎(chǔ)知識(shí)講解
這篇文章主要介紹了Java中反射reflect的基礎(chǔ)知識(shí)講解,Java中的反射,它算是Java當(dāng)中非常底層的一個(gè)技術(shù),平時(shí)我們我們用得不多,實(shí)際上它也的確非常復(fù)雜同時(shí)也難以理解,但是涉及到底層的東西Java都給我們封裝好了,我們直接拿來(lái)調(diào)用即可,需要的朋友可以參考下2023-10-10
Java鏈表中添加元素的原理與實(shí)現(xiàn)方法詳解
這篇文章主要介紹了Java鏈表中添加元素的原理與實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了Java實(shí)現(xiàn)鏈表中添加元素的相關(guān)原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下2020-03-03
基于OpenCV與JVM實(shí)現(xiàn)矩陣處理圖像
本文主要介紹了Java圖像處理實(shí)戰(zhàn)之基于OpenCV與JVM實(shí)現(xiàn)矩陣處理圖像。文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)圖像處理有一定的幫助,感興趣的可以試一試2022-01-01
SpringBoot項(xiàng)目引入MCP的實(shí)現(xiàn)示例
本文主要介紹了SpringBoot項(xiàng)目引入MCP的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-04-04

