spring(3)

本贴最后更新于 2008 天前,其中的信息可能已经东海扬尘

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
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3165 引用 • 8206 回帖 • 1 关注

相关帖子

回帖

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    491 引用 • 1383 回帖 • 370 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    35 引用 • 35 回帖
  • abitmean

    有点意思就行了

    14 关注
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    169 引用 • 799 回帖
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 34 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 286 关注
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    57 引用 • 22 回帖
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 591 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    160 引用 • 470 回帖
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 249 关注
  • 反馈

    Communication channel for makers and users.

    123 引用 • 906 回帖 • 177 关注
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 254 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    710 引用 • 1173 回帖 • 192 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 7 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 8 关注
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 590 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 581 关注
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    198 引用 • 120 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    6357 引用 • 28565 回帖 • 265 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    4 引用 • 7 回帖 • 1 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 594 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 430 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖