问题一:
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.aop.config.internalAutoProxyCreator': Initialization of bean failed; nested exception is java.lang.NoClassDefFoundError: org/aspectj/lang/annotation/Pointcut
解决办法:
加入 下面依赖:
<!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver -->
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.9.6</version>
<scope>runtime</scope>
</dependency>
问题二:使用全注解整合Mybatis 时没能创建Mapper 的Bean
Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.power.node.bank.mapper.AccountMapper' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
解决办法:加入Mapper 扫描
@Bean
public MapperScannerConfigurer getMapperScan(){
MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
mapperScannerConfigurer.setBasePackage("com.power.node.bank.mapper");
return mapperScannerConfigurer;
}
全注解Config 配置:
package com.power.node.bank;
import com.alibaba.druid.pool.DruidDataSource;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.mapper.MapperScannerConfigurer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.EnableAspectJAutoProxy;
import org.springframework.core.io.ClassPathResource;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
/**
*
* @Author darren
* @Date 2022/11/23 19:15
*/
@ComponentScan("com.power.node.bank")
@EnableAspectJAutoProxy
public class SpringConfig {
@Bean(name = "myDruidDataSource")
public DruidDataSource getDruidDataSource(){
DruidDataSource myDruidDataSource = new DruidDataSource();
myDruidDataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
myDruidDataSource.setUrl("jdbc:mysql://localhost:3306/test");
myDruidDataSource.setUsername("root");
myDruidDataSource.setPassword("root");
return myDruidDataSource;
}
@Bean(name = "sqlSessionFactoryBean")
public SqlSessionFactoryBean getSqlSessionFactoryBean(DruidDataSource myDruidDataSource){
SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
sqlSessionFactoryBean.setDataSource(myDruidDataSource);
sqlSessionFactoryBean.setConfigLocation(new ClassPathResource("mybatis-config2.xml"));
sqlSessionFactoryBean.setTypeAliasesPackage("com.power.node.bank.pojo");
return sqlSessionFactoryBean;
}
@Bean
public MapperScannerConfigurer getMapperScan(){
MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
mapperScannerConfigurer.setBasePackage("com.power.node.bank.mapper");
return mapperScannerConfigurer;
}
@Bean(name = "transactionManager")
public DataSourceTransactionManager getTransactionManager(DruidDataSource myDruidDataSource) {
DataSourceTransactionManager dataSourceTransactionManager =
new DataSourceTransactionManager();
dataSourceTransactionManager.setDataSource(myDruidDataSource);
return dataSourceTransactionManager;
}
}
对照XML配置:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd">
<!--组件扫描-->
<context:component-scan base-package="com.power.node.bank"/>
<!--引入外部属性文件-->
<context:property-placeholder location="jdbc.properties"/>
<!--数据源-->
<bean id="myDruidDataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</bean>
<!--SqlSessionFactoryBean 配置-->
<bean class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="myDruidDataSource"/>
<property name="configLocation" value="mybatis-config2.xml"/>
<property name="typeAliasesPackage" value="com.power.node.bank.pojo"/>
</bean>
<!--Mapper 扫描配置器-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.power.node.bank.mapper"/>
</bean>
<!--事务管理器-->
<bean id="txManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="myDruidDataSource"/>
</bean>
<!--启用事务注解-->
<tx:annotation-driven transaction-manager="txManager"/>
</beans>