1、通过注解实现 spring aop
1)打开 aop 注解开关
<context:component-scan base-package="cn.itcast" />
<aop:aspectj-autoproxy /> aop 切面自动代理
2)声明切面类、各种通知
@Component
@Aspect 声明切面类,注意该切面类需要被 spring 当成 component 来管理
@Pointcut("execution(* .add(..))") 可以在一个空的方法上声明切入点,然后在其他通知中直接引用该方法
public void a(){}
@Before("a()") 前置通知
@AfterReturning("a()") 后置通知
@Around("a()") 环绕通知
@AfterThrowing("a()") 异常通知
@After("a()") 最终通知,无论出现异常是否,都会调用该通知
3)2 个代表目标方法对象
JoinPoint :获取当前目标类目标方法的所有信息(当前目标类,方法名,方法中的参数)
Object[] objs = joinPoint.getArgs();
ProceedingJoinPoint:只是在环绕通知中使用,它代表了正在执行的目标方法
2、jdbcTemplate crud 操作
准备工作:
导入 spring-jdbc 数据库驱动坐标
具体工作:
applicationContext.xml 约束 jdbc/spring-jdbc/spring-tx
数据源连接池
jdbcTemplate
写代码:
jdbcTemplate.update("");
1)需要配置数据源(dataSource) spring内置连接池org.springframework.jdbc.datasource.DriverManagerDataSource dbcp连接池org.apache.commons.dbcp.BasicDataSource c3p0连接池com.mchange.v2.c3p0.ComboPooledDataSource druid连接池com.alibaba.druid.pool.DruidDataSource 企业开发中,一般都是把连接数据库的配置放在一个属性文件上,然后引入 <context:property-placeholder location="classpath:db.properties" /> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="driverClassName" value="${jdbc.driver}"></property> <property name="url" value="${jdbc.url}"></property> <property name="username" value="${jdbc.username}"></property> <property name="password" value="${jdbc.password}"></property> </bean> 2)使用jdbcTemplate核心对象操作数据库 <!-- jdbcTemplate对象 --> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <!-- 注入dataSource --> <property name="dataSource" ref="dataSource"></property> </bean> 所以,在dao层,我们可以直接从成员变量中拿到JdbcTemplate对象,然后做crud操作 添加:jdbcTemplate.update("insert into .. values...") 修改:jdbcTemplate.update("update xx set ") 删除:jdbcTemplate.update("delete from ..") 查询:jdbcTemplate.queryForObject()/query()
4.spring 事务管理机制(声明式事务,理解)
参考:
(1)事务管理器,可以选择相关的平台(jdbc、hibernate、jpa) org.springframework.transaction.PlatformTransactionManager 包括下面这些: org.springframework.jdbc.datasource.DataSourceTransactionManager 主要针对于JdbcTemplate、Mybatis开发 org.springframework.orm.jpa.JpaTransactionManager主要针对于JPA开发 HibernateTransactionManager主要针对于Hibernate开发 (2)定义事务的一些特性:隔离、传播、超时、只读
org.springframework.transaction.TransactionDefinition
隔离: ISOLATION_DEFAULT (spring默认采用) ISOLATION_READ_COMMITTED 是oracle默认的隔离级别 ISOLATION_REPEATABLE_READ 是mysql默认的隔离级别 传播: 两个被事务管理的方法互相调用问题,它与数据库无关,是程序内部维护的问题 PROPAGATION_REQUIRED(spring默认值) 两个操作处于同一个事务,如果之前没有事务,新建一个事务 PROPAGATION_REQUIRES_NEW 两个操作处于不同的事务 PROPAGATION_NESTED 它是一种嵌套事务,只对DataSourceTransactionManager起作用 a方法和b方法都在事务的管理当中,a方法调用b方法 a设置为propagation="REQUIRED",b设置为propagation="REQUIRED",a和b在同一个事务里面 a和b要么同时成功,要么同时失败 a设置为propagation="REQUIRED",b设置为propagation="REQUIRES_NEW",a和b不在同一个事务里面 a和b互不影响 a设置为propagation="REQUIRED",b设置为propagation="NESTED",a所在事务嵌套了b事务,用到了保存点机制 a可以影响b,但b不能影响a 保存点:记录出错的方法,便于回滚该方法,默认不开启 当设置propagation="REQUIRED",如当前操作没有事务,会自动加上事务 增删改 如设置propagation="SUPPORTS",如当前操作没有事务,不会自动加上事务 查询 (3)事务的状态 org.springframework.transaction.TransactionStatus
5.spring 声明式事务的配置(2 种方式来配置事务)
为什么要有事务?
因为 dao 层针对数据库做操作,只能是一个一个做。增/删/改/查
实际开发经常要做一组操作,一组操作,就叫做事务,这样的事务都是加在业务层,
就算不是一组操作,有时候也需要回滚,也需要事务。
(1)xml 方式:
<!-- 第二步:配置事务通知 环绕通知+异常通知 --> <tx:advice id="txadvice" transaction-manager="transactionManager"> <tx:attributes> <!-- 增强的方法匹配规则 方法名匹配Service层的方法 --> <tx:method name="transferMoney"/> <tx:method name="delete*"/> <tx:method name="save*"/> <tx:method name="find*"/> <tx:method name="update*"/> </tx:attributes> </tx:advice> <!-- 第三步:配置切面 --> <aop:config> <aop:pointcut expression="execution(* *.transfer*(..))" id="pointCut1"/> <aop:advisor advice-ref="txAdvice" pointcut-ref="pointCut1"/> </aop:config> 实际开发中,经常要改变的就是切入点表达式 <tx:attributes>下面配置的匹配的方法,一定要在expression表达式扫描的包下 (2)注解方式: <!-- 第一步:配置事务管理器:主要要注入数据源 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"></property> </bean> <!-- 第二步:开启事务注解开关:主要是声明事务管理器--> <tx:annotation-driven transaction-manager="transactionManager"/> 第三步:在service层类或方法上@Transactional
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于