在Spring中使用JDBC和JDBC模板的讲解
spring dao层中对jdbc进行了封装,使用模板模式的设计模式,通过ioc被动注入的方式将jdbcTemplate
这个模板类注入到数据对象中,进行数据库操作。
我们要在一个类中进行CRUD
操作(crud主要被用在描述软件系统中数据库或者持久层的基本操作功能。),首先要将jdbcTemplate这个模板类注入到数据对象类中,然后将DataSource
这个类注入到jdbcTemplate,获取数据源。 这样数据对象类就可以通过jdbcTemplate类中的方法进行数据库操作了。
注意:这里需要导如spring jdbc的两个包和数据库驱动包
在Spring中使用JDBC操作数据库时,我们需要通过DataSource获取一个数据库连接,然后开始执行SQL,SQL执行完成后,我们需要处理SQL的结果,最后关闭连接,处理异常等。
无论我们是查询,还是插入或者删除数据,整体过程比较类似,唯一变化的部分是执行的SQL不同,处理SQL的结果的代码不同,其余部分基本相同。所以,如果使用JDBC直接操作数据库,就会使代码中存在很多相似且重复的代码。
为了解决这个问题,Spring为我们提供的解决方案是,使用JDBC模板。Spring的JDBC模板能够承担资源管理和异常处理的工作,从而简化我们的JDBC代码,让我们可以只编写从数据库中读写数据的代码。
对于JDBC来说,Spring提供了3个模板类。
- 1,JdbcTemplate:Spring里最基本的JDBC模板。
- 2,NamedParameterJdbcTemplate:能够在执行查询时,把值绑定到SQL里的命名参数。
- 3,SimpleJdbcTemplate:利用Java5的特性,比如自动装箱,generic和可变参数列表来简化JDBC模板的使用。
具体的使用例子,会像这个样子:
获取到JDBC模板对象后,直接执行SQL即可,jdbcTemplate.update(SQL)
。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接
相关推荐
-
Spring数据访问模板化方法
在读<Spring in Action>一书,读到Spring数据访问模板化的内容时,书中以乘坐飞机拖运行李为例,介绍了模板方法这一设计模式. 在乘坐飞机需要拖运行李时,我们需要需要进行行李登记.然后,将行李交给工作人员,工作人员会对行李进行称重,安全扫描检查,然后通过传送带将行李传送到摆渡车.摆渡车载上行李,将行李拉到飞机.到达目的地后,摆渡车会将行李从飞机上拉到取行李处,然后乘客取走自己的行李. 查看整个过程,这个过程对于所有乘客基本都是相同的.对不同乘客不一样的地方,是登记行李时需要各个
-
在AOP中Spring生成代理类的两种方式
Java 动态代理.具体有如下四步骤: 通过实现 InvocationHandler 接口创建自己的调用处理器: 通过为 Proxy 类指定 ClassLoader 对象和一组 interface 来创建动态代理类: 通过反射机制获得动态代理类的构造函数,其唯一参数类型是调用处理器接口类型: 通过构造函数创建动态代理类实例,构造时调用处理器对象作为参数被传入. 在AOP中,Spring通过生成代理类,来完成切面的织入. Spring生成代理类有2种方式. 如果目标对象实现的是一个接口,Sprin
-
Spring中数据访问对象Data Access Object的介绍
在Spring中,DAO是Data Access Object的简称,即,数据访问对象. 它的名称虽然叫对象,但其实DAO是接口.这个名称很好的描述了DAO在程序中的角色.DAO的作用在于提供一种手段,来读取和写入数据库,他们应该通过接口的方式来提供这种功能,让程序的其他部分可以访问他们,而不必与特定的读取和写入数据库的实现方式进行绑定. 在程序中,与DAO相关的类的关系一般如下图所示. 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们
-
在Spring中编写事务的介绍
理解事务之前,先讲一个你日常生活中最常干的事:取钱. 比如你去ATM机取1000块钱,大体有两个步骤:首先输入密码金额,银行卡扣掉1000元钱:然后ATM出1000元钱.这两个步骤必须是要么都执行要么都不执行.如果银行卡扣除了1000块但是ATM出钱失败的话,你将会损失1000元:如果银行卡扣钱失败但是ATM却出了1000块,那么银行将损失1000元.所以,如果一个步骤成功另一个步骤失败对双方都不是好事,如果不管哪一个步骤失败了以后,整个取钱过程都能回滚,也就是完全取消所有操作的话,这对双方都是
-
Spring对事务管理的支持
Spring对事务的支持有两种方式,一是自己编写事务,精确控制事务的边界,二是采用声明事务的方式,使用AOP来完成.无论哪种方式,我们都将使用一个Spring事务管理连接器连接特定平台的事务实现. Spring不直接管理事务,相反,它提供很多可供选择的事务管理器,将事务管理的责任委托给JTA(Java Transaction Interface)或相应的持久性机制所提供的某个特定平台事务实现. Spring提供的常用的事务管理器有DataSourceTransactionManager,Hibe
-
Spring中配置数据源的几种方式
无论使用什么形式的Spring DAO支持类,都需要配置数据源的引用.Spring提供了多个选项,用于在Spring程序里配置数据库,其中包括: 1,由JDBC驱动程序定义的数据源. 2,由JNDI查询的数据源. 3,连接池的数据源. 在Spring里,我们可以像使用其他Bean一样来配置一个数据源的引用,并且把它装配到其他的类里. 在配置数据源的时候,其实就是配置一个<bean>节点,指定bean的id,指定bean的class,然后,指定bean的属性,比较通用的属性一般会包括driver
-
SpringBoot自动配置的实现原理
一.运行原理 Spring Boot的运行是由注解@EnableAutoConfiguration提供的. @Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Inherited @AutoConfigurationPackage @Import({EnableAutoConfigurationImportSelector.class}) public @interface EnableAuto
-
Spring中的事务隔离级别的介绍
spring事务: 什么是事务: 事务逻辑上的一组操作,组成这组操作的各个逻辑单元,要么一起成功,要么一起失败. 事务特性(4种): 原子性 (atomicity):强调事务的不可分割. 一致性 (consistency):事务的执行的前后数据的完整性保持一致. 隔离性 (isolation):一个事务执行的过程中,不应该受到其他事务的干扰 持久性(durability) :事务一旦结束,数据就持久到数据库 解决读问题: 设置事务隔离级别(5种) DEFAULT 这是一个PlatfromTran
-
Spring中事务传播行为的介绍
传播行为定义关于客户端和被调用方法的事务边界.Spring定义了7种截然不同的传播行为. 1,PROPAGATION_MANDATORY,表示该方法必须运行在一个事务中.如果当前没有事务正在发生,则抛出异常. 2,PROPAGATION_NESTED,表示如果当前有一个事务正在运行当中,则该方法应该运行在一个嵌套事务中.被嵌套的事务可以独立于封装事务进行提交或回滚.如果封装事务不存在,则行为就像PROPAGATION_REQUIRED一样. 3,PROPAGATION_NEVER,表示当前方法不
-
在Spring使用iBatis及配置讲解
就像集成JDBC和其他ORM框架一样,Spring也集成了iBatis. 1,配置iBatis客户模板 iBatis的核心是com.ibatis.sqlmap.SqlMapClient接口.SqlMapClient大致相当于Hibernate的Session或JPA的EntityManager,用于执行全部的数据访问操作. Spring解决iBatis会话管理和异常处理问题的方案是SQLMapClientTemplate.SQLMapClientTemplate包裹了一个SqlMapClient
随机推荐
- EasyUI的treegrid组件动态加载数据问题的解决办法
- 原生JavaScript实现精美的淘宝轮播图效果示例【附demo源码下载】
- 详解springboot 使用c3p0数据库连接池的方法
- iOS手势识别的详细使用方法(拖动,缩放,旋转,点击,手势依赖,自定义手势)
- python数据结构之列表和元组的详解
- 关于js二维数组和多维数组的定义声明(详解)
- python中for语句简单遍历数据的方法
- jsp中自定义Taglib详解
- C语言二叉树的非递归遍历实例分析
- 分享10段PHP常用代码
- MYSQL数据表损坏的原因分析和修复方法小结(推荐)
- C# FTP操作类分享
- Java字符流和字节流对文件操作的区别
- Android编程获取组件尺寸大小的方法
- 人工智能最火编程语言 Python大战Java!
- java8版本base64加密解密的实例
- 解决vue打包后vendor.js文件过大问题
- 详细整理python 字符串(str)与列表(list)以及数组(array)之间的转换方法
- php设计模式之单例模式用法经典示例分析
- js for终止循环 跳出多层循环