spring_02_在中间层的使用
来源:互联网 发布:php 设置session id 编辑:程序博客网 时间:2024/06/05 15:50
一、Spring管理数据源:
1. 不带连接池DataSource:
2. 带C3P0连接池的DataSource:
3. 带C3P0连接池,把连接参数配置在独立的属性中的DataSource:
二、Spring对JDBC的支持:
1. 提供了两种封装方式:模板类,DAO支持类
2. 模板类:SimpleJdbcTemplate---> CRUD
3. DAO支持类:SimpleJdbcDaoSupport,不推荐使用。
三、Spring的事务管理:Spring提供了针对不同持久化机制的事务管理器。(AOP中的切面类,定义了很多通知)
如:hibernate有org.springframework.orm.hibernate3.HibernateTransactionManager
1、事务的参数:
1) 事务的传播行为:
a) PROPAGATION_REQUIRED:当前方法必须在一个事务中运行。如果一个事务正在运行,该方法将会在那个事务中运行。否则就要开始一个新事务。Spring的TransactionDefinition的默认传播行为。
b) PROPAGATION_SUPPORTS:当前方法不需要事务性上下文。如果有一个事务正在进行,它也可以在这个事务里运行。
c) PROPAGATION_MANDATORY:当前方法必须在一个事务中运行。如果有一个事务正在进行,该方法将会在那个事务中运行。如果没有一个活动的事务,则抛出异常。
d) PROPAGATION_REQUIRES_NEW:当前方法必须在它自己的事务里运行。总是开启一个新的事务,如果有一个事务正在运行,则将在这个方法的运行期间被挂起。
e) PROPAGATION_NOT_SUPPORTED:当前方法总是非事务地执行。如果有一个事务正在运行,它将在这个方法的运行期间被挂起。
f) PROPAGATION_NEVER:当前方法不能在一个事务上下文中。如果有一个事务正在运行,则抛出异常。
g) PROPAGATION_NESTED:如果当前有一事务正在运行,则该方法运行在一个嵌套式事务中。如果没有活动事务, 则按ROPAGATION_REQUIRED 属性执行。
2) 隔离级别:
a) ISOLATION_DEFAULT:使用数据库默认的事务隔离级别。Spring的PlatfromTransactionManager的默认隔离级别.
b) ISOLATION_READ_UNCOMMITTED:它充许另一个事务可以看到这个事务未提交的数据。隔离级别最低。这种隔离级别会产生脏读,不可重复读和幻读。
c) ISOLATION_READ_COMMITTED: 保证一个事务修改的数据提交后才能被另外一个事务读取。可能出现不可重复读和幻读。
d) ISOLATION_REPEATABLE_READ: 这种事务隔离级别可以防止脏读,不可重复读。
可能出现幻像读。
e) ISOLATION_SERIALIZABLE:事务被处理为顺序执行。可以防止脏读、不可重复读、幻读。隔离级别最高。
3) 只读状态:只读事务只对后端数据库执行读操作,后端数据库可以采用一些优化措施来提高效率。
4) 事务超时:指定事务在特定秒数后自动回滚,不必等它自己结束。事务超时默认是依赖于事务系统的,或者事务超时没有被支持。
5) 回滚规则:定义哪些异常引起事务回滚,哪些不引起。
默认情况下只在出现RuntimeException才会回滚,而在出现受检异常时不回滚。(跟EJB中的回滚行为一致)
你可以声明一个事务在出现特定的受检异常时能回滚。也可以声明一个事务在出现特定的非受检异常时不回滚。
2、声明式事务管理
1) 配置Spring提供的对应持久化技术的事务管理器。
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
2) 配置事务参数(配置通知)
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*" />
<tx:method name="find*" read-only="true"/>
</tx:attributes>
</tx:advice>
3) AOP的配置:
<aop:config>
<!-- 通知者 -->
<aop:advisor advice-ref="txAdvice" pointcut="execution(* com.qiujy.service.*.*(..))"/>
</aop:config>
3.基于注解的事务管理配置:
1) 配置事务管理器。
2) 启用Spring对事务注解的支持:<tx:annotation-driven transaction-manager="transactionManager"/>
3) 使用@Transactional对相应的类或方法添加事务配置:事务参数的配置参看Spring reference。
四、Spring整合hibernate:
1. 添加hibernate所需要的包:
2. 在classpath上添加Hibernate的配置文件。
3. 在Spring配置文件中添加sessionFactory的配置:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation" value="classpath:hibernate.cfg.xml"/>
<property name="dataSource" ref="dataSource"/>
</bean>
4.为了解耦。我们给Hibernate的DAO类注入的是SessionFactory。
如果不考虑侵入性,可以使用Spring提供的HibernateTemplate类,和HibernateDaoSupport类。
5.hibernate的编码跟以前没有区别,事务的管理也是通过Spring的事务管理机制来管理。
五、Spring提供的邮件抽象层
六、Spring提供定时任务调度,整合Quratz框架。
1. 不带连接池DataSource:
2. 带C3P0连接池的DataSource:
3. 带C3P0连接池,把连接参数配置在独立的属性中的DataSource:
二、Spring对JDBC的支持:
1. 提供了两种封装方式:模板类,DAO支持类
2. 模板类:SimpleJdbcTemplate---> CRUD
3. DAO支持类:SimpleJdbcDaoSupport,不推荐使用。
三、Spring的事务管理:Spring提供了针对不同持久化机制的事务管理器。(AOP中的切面类,定义了很多通知)
如:hibernate有org.springframework.orm.hibernate3.HibernateTransactionManager
1、事务的参数:
1) 事务的传播行为:
a) PROPAGATION_REQUIRED:当前方法必须在一个事务中运行。如果一个事务正在运行,该方法将会在那个事务中运行。否则就要开始一个新事务。Spring的TransactionDefinition的默认传播行为。
b) PROPAGATION_SUPPORTS:当前方法不需要事务性上下文。如果有一个事务正在进行,它也可以在这个事务里运行。
c) PROPAGATION_MANDATORY:当前方法必须在一个事务中运行。如果有一个事务正在进行,该方法将会在那个事务中运行。如果没有一个活动的事务,则抛出异常。
d) PROPAGATION_REQUIRES_NEW:当前方法必须在它自己的事务里运行。总是开启一个新的事务,如果有一个事务正在运行,则将在这个方法的运行期间被挂起。
e) PROPAGATION_NOT_SUPPORTED:当前方法总是非事务地执行。如果有一个事务正在运行,它将在这个方法的运行期间被挂起。
f) PROPAGATION_NEVER:当前方法不能在一个事务上下文中。如果有一个事务正在运行,则抛出异常。
g) PROPAGATION_NESTED:如果当前有一事务正在运行,则该方法运行在一个嵌套式事务中。如果没有活动事务, 则按ROPAGATION_REQUIRED 属性执行。
2) 隔离级别:
a) ISOLATION_DEFAULT:使用数据库默认的事务隔离级别。Spring的PlatfromTransactionManager的默认隔离级别.
b) ISOLATION_READ_UNCOMMITTED:它充许另一个事务可以看到这个事务未提交的数据。隔离级别最低。这种隔离级别会产生脏读,不可重复读和幻读。
c) ISOLATION_READ_COMMITTED: 保证一个事务修改的数据提交后才能被另外一个事务读取。可能出现不可重复读和幻读。
d) ISOLATION_REPEATABLE_READ: 这种事务隔离级别可以防止脏读,不可重复读。
可能出现幻像读。
e) ISOLATION_SERIALIZABLE:事务被处理为顺序执行。可以防止脏读、不可重复读、幻读。隔离级别最高。
3) 只读状态:只读事务只对后端数据库执行读操作,后端数据库可以采用一些优化措施来提高效率。
4) 事务超时:指定事务在特定秒数后自动回滚,不必等它自己结束。事务超时默认是依赖于事务系统的,或者事务超时没有被支持。
5) 回滚规则:定义哪些异常引起事务回滚,哪些不引起。
默认情况下只在出现RuntimeException才会回滚,而在出现受检异常时不回滚。(跟EJB中的回滚行为一致)
你可以声明一个事务在出现特定的受检异常时能回滚。也可以声明一个事务在出现特定的非受检异常时不回滚。
2、声明式事务管理
1) 配置Spring提供的对应持久化技术的事务管理器。
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
2) 配置事务参数(配置通知)
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*" />
<tx:method name="find*" read-only="true"/>
</tx:attributes>
</tx:advice>
3) AOP的配置:
<aop:config>
<!-- 通知者 -->
<aop:advisor advice-ref="txAdvice" pointcut="execution(* com.qiujy.service.*.*(..))"/>
</aop:config>
3.基于注解的事务管理配置:
1) 配置事务管理器。
2) 启用Spring对事务注解的支持:<tx:annotation-driven transaction-manager="transactionManager"/>
3) 使用@Transactional对相应的类或方法添加事务配置:事务参数的配置参看Spring reference。
四、Spring整合hibernate:
1. 添加hibernate所需要的包:
2. 在classpath上添加Hibernate的配置文件。
3. 在Spring配置文件中添加sessionFactory的配置:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation" value="classpath:hibernate.cfg.xml"/>
<property name="dataSource" ref="dataSource"/>
</bean>
4.为了解耦。我们给Hibernate的DAO类注入的是SessionFactory。
如果不考虑侵入性,可以使用Spring提供的HibernateTemplate类,和HibernateDaoSupport类。
5.hibernate的编码跟以前没有区别,事务的管理也是通过Spring的事务管理机制来管理。
五、Spring提供的邮件抽象层
六、Spring提供定时任务调度,整合Quratz框架。
- spring_02_在中间层的使用
- Unity3D研究之在Unity中使用事件/委托机制(event/delegate)进行GameObject之间的通信引入中间层
- 使用express作为前端和后台的中间层Demo
- 中间层
- 中间层
- 中间层
- 中间层
- 【Unity3D技巧】在Unity中使用事件/委托机制(event/delegate)进行GameObject之间的通信 (二) : 引入中间层NotificationCenter
- 报表应用的计算中间层
- 报表应用的计算中间层
- 【原创】NDIS中间层驱动开发在Win7系统下和Windows XP系统下的区别
- NDIS中间层驱动开发在Win7系统下和Windows XP系统下的区别
- NDIS中间层驱动开发在Win7系统下和Windows XP系统下的区别
- NAT在NDIS中间层驱动中的实现
- NAT在NDIS中间层驱动中的实现
- NAT在NDIS中间层驱动中的实现
- NAT在NDIS中间层驱动中的实现
- 关于K3中间层注册后,服务器注销或锁定状态,客户端无法使用的解决方案
- 使用office2003打开docx文件
- 最小生成树模版(Prime+邻接表)
- android游戏开发适应多屏幕的问题
- 博客的开始
- spring_01_核心技术
- spring_02_在中间层的使用
- spring_03_在Web层的应用.
- Sub-process /usr/bin/dpkg returned an error code (1) 的解决办法
- 真爱如血 精彩出乎我意料
- 不真实的景象
- 触动人心:如何设计优秀的iPhone应用
- TOMCAT下,File对象,访问网络路径下文件失败的解决方案
- 帮助提示工具Toast的简单使用
- LCD驱动学习笔记