JAVA之Spring学习(第三天)

23 篇文章 0 订阅
7 篇文章 0 订阅

一,学习大纲

声明式事务
事务传播行为
事务隔离级别
只读事务
事务回滚
常用注解
Ajax 复习

.自动注入

        1.在 S pring 配置文件中 对象名和 ref=”id”id 名相同使用自动注入 , 可以 不配置 <property/>
        2.两种配置办法
                2.1在<bean>中通过 autowire=”” 配置 , 只对这个 <bean> 生效
                2.2 在<beans> 中通过 default-autowire=”” 配置,表当当前文件中所有<bean>都是全局配                        置内容
        3.autowire=”” 可取值
                3.1 default: 默认值, 根据全局 default-autowire=”” . 默认全局和局 部都没有配置情况下 ,    相当于 no
                3.2 no: 不自动注入3.3 byName: 通过名称自动注入 . Spring 容器中找类的 Id
                3.4 byType: 根据类型注入.
                        3.4.1 spring 容器中不可以出现两个相同类型的<bean>
                3.5 constructor: 根据构造方法注入.
                        3.5.1 提供对应参数的构造方法(构造方法参数中包含注入对戏那个 )
                        3.5.2 底层使用 byName, 构造方法参数名和其他 <bean> id 相同 .

三, Spring 中加载 properties 文件

        1.在 src 下新建 xxx.properties 文件
        2.在 spring 配置文件中先引入 xmlns:context, 在下面添加
        2.1 如果需要记载多个配置文件逗号分割
<context:property-placeholder location="classpath:db.properties"/>
        3. 添加了属性文件记载 , 并且在 <beans> 中开启自动注入注意的地方
                3.1 SqlSessionFactoryBean 的 id 不能叫做 sqlSessionFactory
                3.2 修改
                        3.2.1 把原来通过ref引用替换成 value 赋值 , 自动注入只能影响 ref, 不会影响 value 赋值
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> 
        <property name="basePackage" value="com.bjsxt.mapper"></property>
        <property name="sqlSessionFactoryBeanName" value="factory"></property>
 </bean>
        4. 在被 Spring 管理的类中通过 @Value(“${key}”) 取出 properties 中内容
                4.1 添加注解扫描
<context:component-scan base-package="com.bjsxt.service.impl"></context:compo nent-scan>
                4.2 在类中添加
                        4.2.1 key 和变量名可以不相同
                        4.2.2 变量类型任意,只要保证 key 对应的 value 能转换成这个 类型就可以
@Value("${my.demo}") 
private String test;

.scope 属性

        1. <bean>的属性 ,
        2. 作用 : 控制对象有效范围 ( 单例 , 多例等 )
        3.<bean/>标签对应的对象默认是单例的 .
                3.1 无论获取多少次, 都是同一个对象
        4.scope 可取值
                4.1 singleton 默认值, 单例
                4.2 prototype 多例, 每次获取重新实例化
                4.3 request每次请求重新实例化
                4.4 session每个会话对象内 , 对象是单例的 .
                4.5 application 在 application 对象内是单例
                4.6 global session spring 推 出 的 一 个 对 象 , 依 赖 于 spring-webmvc-portlet , 类似于 session

.单例设计模式

        1. 作用 : 在应用程序有保证最多只能有一个实例 .
        2.好处:
                2.1提升运行效率.
                2.2实现数据共享. 案例 :application 对象
        3.懒汉式
                3.1对象只有被调用时才去创建.
                3.2示例代码
package com.ljx.text;

import javax.sound.midi.MidiDevice.Info;
/**
 * 懒汉式单例模式
 * @author Administrator
 *
 */
public class SingleTon {
	private static SingleTon singleTon;
	
	/**
	 * 如果是写单例模式,构造方法必须私有化,不能被其他类Nwe出来
	 */
	private SingleTon() {}
	
	/**
	 * 提供一个方法
	 * @return
	 */
	public static SingleTon Info() {
		if(singleTon==null) {
			  //在多线程情况下,有可能出现if同时成立的情况,所以需要加锁
			synchronized (SingleTon.class) {
				if(singleTon==null) {
				singleTon=new SingleTon();
				}
			}
		}
		return  singleTon;
	}

}
                3.3 由于添加了锁, 所以导致效率低 .
        4. 饿汉式
                4.1 解决了懒汉式中多线程访问可能出现同一个对象和效率低问
import javax.sound.midi.MidiDevice.Info;

import org.apache.catalina.ssi.SSIInclude;
/**
 * 饿汉式单例模式
 * @author Administrator
 *
 */
public class SingleTon {
	private static SingleTon singleTon = new SingleTon();
	private SingleTon() {}
	public static SingleTon Info() {
		return  singleTon;
	}
}

. 声明式事务

        1.编程式事务 :
                1.1 由程序员编程事务控制代码.
                1.2 OpenSessionInView 编程式事务
        2.声明式事务 :
                2.1 事务控制代码已经由 spring 写好 . 程序员只需要声明出哪些方 法需要进行事务控制和如何进行事务控制 .
        3.声明式事务都是针对于 ServiceImpl 类下方法的 .
        4.事务管理器基于通知 (advice) .
        5.在 spring 配置文件中配置声明式事务
 <!--声明式事物是基于AOP的  -->
      <!--配置声明式事物  -->
      <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"></bean>
      <tx:advice id="txAdvice" transaction-manager="txManager">
         <tx:attributes>
         <!--那些方法需要事物  -->
         <!--以ins开头的方法  -->
             <tx:method name="ins*"/>
             <tx:method name="*"/>
         </tx:attributes>
      </tx:advice>
      <!--配置AOP切面  -->
      <aop:config>
      <!--切点的位置设置的大一些  -->
        <aop:advisor advice-ref="execution(* com.ljx.service.impl.*.*(..))" pointcut-ref="txAdvice"/>
      </aop:config>

.声明式事务中属性解释

        1. name=”” 哪些方法需要有事务控制

                1.1 支持* 通配符

        2.readonly=”boolean” 是否是只读事务.

                2.1 如果为 true, 告诉数据库此事务为只读事务 . 数据化优化 , 会对
                      性能有一定提升,所以只要是查询的方法, 建议使用此数据 .
                2.2 如果为 false( 默认值 ), 事务需要提交的事务 . 建议新增 , 删除 ,
                      改.

        3.propagation 控制事务传播行为.

                3.1 当一个具有事务控制的方法被另一个有事务控制的方法调用
                      后,需要如何管理事务( 新建事务 ? 在事务中执行 ? 把事务挂起 ? 报异
                        常?)
                3.2 REQUIRED (默认值): 如果当前有事务 , 就在事务中执行 , 如果当
                        前没有事务,新建一个事务.
                3.3 SUPPORTS:如果当前有事务就在事务中执行, 如果当前没有事
                        务,就在非事务状态下执行.
                3.4 MANDATORY:必须在事务内部执行, 如果当前有事务 , 就在事务
                        中执行,如果没有事务, 报错 .
                3.5 REQUIRES_NEW:必须在事务中执行, 如果当前没有事务 , 新建事
                        务,如果当前有事务, 把当前事务挂起 .
                3.6 NOT_SUPPORTED:必须在非事务下执行, 如果当前没有事务 ,
                        常执行,如果当前有事务, 把当前事务挂起 .
                3.7 NEVER:必须在非事务状态下执行, 如果当前没有事务 , 正常执行 ,
                        如果当前有事务,报错.
                3.8 NESTED:必须在事务状态下执行. 如果没有事务 , 新建事务 , 如果 当前有事务 ,
                        创建一个嵌套事务.

        4. isolation=”” 事务隔离级别

                4.1在多线程或并发访问下如何保证访问到的数据具有完整性的.
                4.2脏读:
                        4.2.1 一个事务(A)读取到另一个事务 (B) 中未提交的数据 , 另一
                                个事务中数据可能进行了改变,此时 A事务读取的数据可能和数据
                                库中数据是不一致的,此时认为数据是脏数据,读取脏数据过程叫
                                做脏读.
                4.3 不可重复读:
                        4.3.1主要针对的是某行数据.(或行中某列)
                        4.3.2主要针对的操作是修改操作.
                        4.3.3两次读取在同一个事务内
                        4.3.4当事务 A 第一次读取事务后, 事务 B 对事务 A 读取的淑君
                                进行修改,事务 A 中再次读取的数据和之前读取的数据不一致 ,
                                程不可重复读.
                4.4 幻读:
                        4.4.1主要针对的操作是新增或删除
                        4.4.2两次事务的结果.
                        4.4.3事务 A 按照特定条件查询出结果, 事务 B 新增了一条符合
                                条件的数据.事务 A 中查询的数据和数据库中的数据不一致的 ,
                                务 A 好像出现了幻觉,这种情况称为幻读 .
                4.5 DEFAULT: 默认值, 由底层数据库自动判断应该使用什么隔离界
                4.6 READ_UNCOMMITTED: 可以读取未提交数据, 可能出现脏读 ,
                               重复读,幻读.
                        4.6.1 效率最高.
                4.7 READ_COMMITTED:只能读取其他事务已提交数据. 可以防止脏
                                读,可能出现不可重复读和幻读.
                4.8 REPEATABLE_READ: 读取的数据被添加锁, 防止其他事务修改
                                此数据,可以防止不可重复读.脏读 , 可能出现幻读 .
                4.9 SERIALIZABLE: 排队操作, 对整个表添加锁 . 一个事务在操作数
                                据时,另一个事务等待事务操作完成后才能操作这个表.
                        4.9.1最安全的
                        4.9.2效率最低的.

        5.rollback-for=”异常类型全限定路径

                5.1当出现什么异常时需要进行回滚
                5.2建议:给定该属性值 .
                        5.2.1 手动抛异常一定要给该属性值.

        6.no-rollback-for=””

                6.1 当出现什么异常时不滚回事务

八.Spring 中常用注解.

        1.@Component 创建类对象 , 相当于配置 <bean/>
        2.@Service 与 @Component 功能相同 . 2.1 写在 ServiceImpl 类上 .
        3.@Repository 与 @Component 功能相同 .
                3.1 写在数据访问层类上.
        4.@Controller 与 @Component 功能相同 .
                4.1 写在控制器类上.
        5.@Resource(不需要写对象的 get/set)
                5.1 java 中的注解
                5.2 默认按照 byName 注入 , 如果没有名称对象 , 按照 byType 注入
                        5.2.1 建议把对象名称和 spring 容器中对象名相同
        6.@Autowired(不需要写对象的 get/set)
                6.1 spring 的注解
                6.2 默认按照 byType 注入 .
        7.@Value() 获取 properties 文件中内容
        8.@Pointcut() 定义切点
        9.@Aspect() 定义切面类
        10.@Before() 前置通知
        11.@After 后置通知
        12.@AfterReturning后置通知 , 必须切点正确执行
        13.@AfterThrowing 异常通知
        14.@Arround 环绕通知

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值