81、SimpleJdbcTemplate

SimpleJdbcTemplate类也是基于JdbcTemplate类,但利用Java5+的可变參数列表和自己主动装箱和拆箱从而获取更简洁的代码。

SimpleJdbcTemplate主要提供两类方法:query及queryForXXX方法、update及batchUpdate方法。

82、集成Spring JDBC及最佳实践

大多数情况下Spring JDBC都是与IOC容器一起使用。通过配置方式使用Spring JDBC。   并且大部分时间都是使用JdbcTemplate类(或SimpleJdbcTemplate和NamedParameterJdbcTemplate)进行开发。就可以能80%时间使用JdbcTemplate类,而仅仅有20%时间使用其它类开发,符合80/20法则。

Spring JDBC通过实现DaoSupport来支持一致的数据库訪问。SpringJDBC提供例如以下DaoSupport实现:

JdbcDaoSupport:用于支持一致的JdbcTemplate訪问。

NamedParameterJdbcDaoSupport:继承JdbcDaoSupport,同一时候提供NamedParameterJdbcTemplate訪问;

SimpleJdbcDaoSupport:继承JdbcDaoSupport,同一时候提供SimpleJdbcTemplate訪问。

因为JdbcTemplate、NamedParameterJdbcTemplate、SimpleJdbcTemplate类使用DataSourceUtils获取及释放连接,并且连接是与线程绑定的,因此这些JDBC模板类是线程安全的。即JdbcTemplate对象能够在多线程中重用。

83、Spring对ORM的支持

Spring对ORM的支持主要表如今下面方面:

一致的异常体系结构,对第三方ORM框架抛出的专有异常进行包装。从而在使我们在Spring中仅仅看到DataAccessException异常体系。

一致的DAO抽象支持:提供类似与JdbcSupport的DAO支持类HibernateDaoSupport。使用HibernateTemplate模板类来简化经常使用操作。HibernateTemplate提供回调接口来支持复杂操作;

Spring事务管理:Spring对全部数据訪问提供一致的事务管理,通过配置方式,简化事务管理。

Spring还在測试、数据源管理方面提供支持,从而同意方便測试。简化数据源使用。

84、标准SQL规范中定义了四种隔离级别:

未提交读(ReadUncommitted):最低隔离级别。一个事务能读取到别的事务未提交的更新数据,非常不安全。可能出现丢失更新、脏读、不可反复读、幻读。

提交读(ReadCommitted):一个事务能读取到别的事务提交的更新数据,不能看到未提交的更新数据,不可能可能出现丢失更新、脏读。但可能出现不可反复读、幻读;

可反复读(RepeatableRead):保证同一事务中先后运行的多次查询将返回同一结果,不受其它事务影响。可能可能出现丢失更新、脏读、不可反复读,但可能出现幻读。

序列化(Serializable):最高隔离级别。不同意事务并发运行,而必须串行化运行,最安全。不可能出现更新、脏读、不可反复读、幻读。

隔离级别越高。数据库事务并发运行性能越差。能处理的操作越少。

因此在实际项目开发中为了考虑并发性能一般使用提交读隔离级别,它能避免丢失更新和脏读,虽然不可反复读和幻读不能避免,但能够在可能出现的场合使用悲观锁或乐观锁来解决这些问题。

85、数据库事务类型

数据库事务类型有本地事务和分布式事务:

本地事务:就是普通事务,能保证单台数据库上的操作的ACID,被限定在一台数据库上。

分布式事务:涉及两个或多个数据库源的事务。即跨越多台同类或异类数据库的事务(由每台数据库的本地事务组成的)。分布式事务旨在保证这些本地事务的全部操作的ACID,使事务能够跨越多台数据库;

86、Java事务类型

Java事务类型有JDBC事务和JTA事务:

JDBC事务:就是数据库事务类型中的本地事务,通过Connection对象的控制来管理事务;

JTA事务:JTA指Java事务API(Java TransactionAPI),是Java EE数据库事务规范。 JTA仅仅提供了事务管理接口。由应用程序server厂商(如WebSphere Application Server)提供实现,JTA事务比JDBC更强大,支持分布式事务。

87、Java EE事务类型

Java EE事务类型有本地事务和全局事务:

本地事务:使用JDBC编程实现事务;

全局事务:由应用程序server提供,使用JTA事务;

88、按是否通过编程实现事务

按是否通过编程实现事务有声明式事务和编程式事务;

声明式事务: 通过注解或XML配置文件指定事务信息;

编程式事务:通过编写代码实现事务。

89、Spring提供的事务管理

Spring框架最核心功能之中的一个就是事务管理,并且提供一致的事务管理抽象,这能帮助我们:

提供一致的编程式事务管理API,无论使用Spring JDBC框架还是集成第三方框架使用该API进行事务编程;

无侵入式的声明式事务支持。

Spring支持声明式事务和编程式事务事务类型。

90、Spring对编程式事务的支持

Spring中的事务分为物理事务和逻辑事务。

物理事务:就是底层数据库提供的事务支持,如JDBC或JTA提供的事务;

逻辑事务:是Spring管理的事务。不同于物理事务,逻辑事务提供更丰富的控制,并且假设想得到Spring事务管理的优点,必须使用逻辑事务,因此在Spring中假设没特别强调一般就是逻辑事务;

逻辑事务即支持很低级别的控制。也有高级别解决方式:

低级别解决方式

工具类:使用工具类获取连接(会话)和释放连接(会话),如使用org.springframework.jdbc.datasource包中的ConnectionUtils类来获取和释放具有逻辑事务功能的连接。

当然对集成第三方ORM框架也提供了类似的工具类,如对Hibernate提供了SessionFactoryUtils工具类,JPA的EntityManagerFactoryUtils等,其它工具类都是使用类似***Utils命名;

//获取具有Spring事务(逻辑事务)管理功能的连接
DataSourceUtils.getConnection(DataSource dataSource)
//释放具有Spring事务(逻辑事务)管理功能的连接
DataSourceUtils.releaseConnection(Connection con, DataSource)

TransactionAwareDataSourceProxy:使用该数据源代理类包装须要Spring事务管理支持的数据源,该包装类必须位于最外层,主要用于遗留项目中可能直接使用数据源获取连接和释放连接支持或希望在Spring中进行混合使用各种持久化框架时使用。其内部实际使用ConnectionUtils工具类获取和释放真正连接。

<!--使用该方式包装数据源。必须在最外层,targetDataSource 知道目标数据源-->
<bean id="dataSourceProxy" class="org.springframework.jdbc.datasource.TransactionAwareDataSourceProxy">
<property name="targetDataSource" ref="dataSource"/>
</bean>

通过如上方式包装数据源后,能够在项目中使用物理事务编码的方式来获得逻辑事务的支持。即支持直接从DataSource获取连接和释放连接,且这些连接自己主动支持Spring逻辑事务;

高级别解决方式

模板类:使用Spring提供的模板类。如JdbcTemplate、HibernateTemplate和JpaTemplate模板类等,而这些模板类内部事实上是使用了低级别解决方式中的工具类来管理连接或会话。

Spring提供两种编程式事务支持:直接使用PlatformTransactionManager实现和使用TransactionTemplate模板类,用于支持逻辑事务管理。假设採用编程式事务推荐使用TransactionTemplate模板类和高级别解决方式。

【面试】【Spring常见问题总结】【09】的更多相关文章

  1. Spring常见问题总结

    1. 什么是 Spring 框架? Spring 是一种轻量级开发框架,旨在提高开发人员的开发效率以及系统的可维护性.Spring 官网:https://spring.io/. 我们一般说 Sprin ...

  2. 【面试】【Spring常见问题总结】【07】

    [常见面试问题总结文件夹>>>] 61.Spring IoC容器的依赖有两层含义: Bean依赖容器:也就是说Bean要依赖于容器,这里的依赖是指容器负责创建Bean并管理Bean的 ...

  3. 【面试 spring boot】【第十七篇】spring boot相关面试

    spring boot相关面试 ====================================================== 1.spring boot启动类  启动原理 参考:htt ...

  4. 面试Spring之bean的生命周期

    找工作的时候有些人会被问道Spring中Bean的生命周期,其实也就是考察一下对Spring是否熟悉,工作中很少用到其中的内容,那我们简单看一下. 在说明前可以思考一下Servlet的生命周期:实例化 ...

  5. 面试-Spring理解

    转自http://hui.sohu.com/infonews/article/6331404387079946240 spring呢,是pivotal公司维护的一系列开源工具的总称,最为人所知的是sp ...

  6. 【5】进大厂必须掌握的面试题-Java面试-spring

    spring面试问题 Q1.什么是spring? Spring本质上是一个轻量级的集成框架,可用于用Java开发企业应用程序. Q2.命名Spring框架的不同模块. 一些重要的Spring Fram ...

  7. spring常见问题

    问题1:提示说:cvc-elt.1: Cannot find the declaration of element 'beans' 解决方法:从网上搜了一些,有的说是因为网络原因访问不到xsd文件,因 ...

  8. 【专访】【Spring常见问题汇总】【05】

    种: 传播行为:传播行为定义了client与彼调用方法之间的事务边界. 隔离级别:隔离级别定义了一个事务可能受其它并发事务影响的程度. 仅仅读:表明事务是否是仅仅读的. 事务超时:指定事务执行的最长时 ...

  9. Spring Security(09)——Filter

    目录 1.1     Filter顺序 1.2     添加Filter到FilterChain 1.3     DelegatingFilterProxy 1.4     FilterChainPr ...

随机推荐

  1. Mongodb数据备份恢复

    Mongodb数据备份恢复 一.MongoDB数据库导入导出操作 1.导出数据库 twangback为备份的文件夹 命令: mongodump -h 127.0.0.1[服务器IP] -d advie ...

  2. surfaceflinger中各个layer的排序

    surfaceflinger的主要工作就是负责把上层传递下来的各个不同的layer进行composition. 这里,我们来讨论一下各个layer在surfaceflinger中的上下排序关系和相关的 ...

  3. 13、Cocos2dx 3.0三,找一个小游戏开发3.0中间Director :郝梦主,一统江湖

    重开发人员的劳动成果.转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/27706967 游戏中的基本元素 在曾经文章中,我们具 ...

  4. mysql主键设置成auto_increment时,进行并发性能測试出现主键反复Duplicate entry &#39;xxx&#39; for key &#39;PRIMARY&#39;

    mysql主键设置成auto_increment时,进行并发性能測试出现主键反复Duplicate entry 'xxx' for key 'PRIMARY' 解决方法: 在my.cnf的[mysql ...

  5. php如何判断用户是从指定页面跳转进来的

    $_SERVER['HTTP_REFERER']下'HTTP_REFERER' 引导用户代理到当前页的前一页的地址(如果存在).由 user agent 设置决定.并不是所有的用户代理都会设置该项,有 ...

  6. [jQuery]地图浏览:如何实现图片的放大缩小和点击之后的位置居中

    HTML代码: <!DOCTYPE html> <html> <head> <script src="http://ajax.googleapis. ...

  7. google多语言通信框架gRPC

    google多语言通信框架gRPC系列(一)概述 gRPC概述 3/26/2016 9:16:08 AM 目录 一.概述 二.编译gRPC 三.C#中使用gRPC 四.C++中使用gRPC 一直在寻找 ...

  8. Spring Bean的作用域(转)

    Spring Bean的作用域 .singleton  [单例] eg:<bean id="personService" class="com.yinger.ser ...

  9. POJ---2243 Knight Moves 使用A*算法的广度优先搜索

    题目链接:http://poj.org/problem?id=2243 启发式搜索:启发式搜索就是在状态空间中的搜索对每一个搜索的位置进行评估,得到最好的位置,再从这个位置进行搜索直到目标.这样可以省 ...

  10. fedora linux平台下搭建lighttpd+php+sqlite

    (一)lighttpd 1. 安装 yum install lighttpd 安装完毕后,系统中应该多了一个用户lighttpd和组lighttpd.这个用户,默认是不同意登陆的. 我们改动/etc/ ...