概念

  jdbcTemplate就Spring对数据库持久化技术的实现,通过它可以对数据库进行CRUD等操作。

JDBCTemplate和代码实现

public void jdbcadd() {
DriverManagerDataSource dataSource = new DriverManagerDataSource();
//加载数据库驱动
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql:///dbname");
dataSource.setUsername("root");
dataSource.setPassword("123"); //设置数据源
JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);
String sql = "insert into user values(?,?)";
jdbcTemplate.update(sql,"blue", 123);
}
}

底层JDBC实现代码

public void jdbcimpl() {
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null; try {
Class.forName("com.mysql.jdbc.Driver");
conn = DriverManager.getConnection("jdbc:mysql:///dbname", "root", "123");
String sql = "select * from user WHERE name=?";
ps = conn.prepareStatement(sql);
ps.setString(1, "blueto");
rs = ps.executeQuery(); //执行
while (rs.next()) {
String name = rs.getString("username");
User user = new User();
user.setName(name);
} } catch (Exception e) {
e.printStackTrace();
}
}

spring 连接池配置

  c3p0的连接池代码是怎么样实现的呢?红色部分为与前面第一种方式不同的部分

public void c3p0impl(){
ComboPooledDataSource dataSource = new ComboPooledDataSource();
//加载数据库驱动
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setJdbcUrl("jdbc:mysql:///dbname");
dataSource.setUser("root");
dataSource.setPassword("123"); //设置数据源
JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);
String sql = "insert into user values(?,?)";
jdbcTemplate.update(sql, "blue", 123);
}

  实际的spring项目开发中,是不会像前面那样创建数据库连接conn再去请求执行sql语句的,而是在配置文件中配置好连接池。

  从代码的实现步骤来看,可以总结 出连接池的执行步骤:

  第一步 创建连接池的ComboPooledDataSource 对象

  第二步 将数据库的驱动,url,用户,密码作为属性注入到Datasource对象中

  好了,现在再按上面的步骤在配置文件中配置就可以了,现在应该明白别人那样配置了吧,配置文件可写成这样

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id = "dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql:///dbname"></property>
<property name="user" value="root"></property>
<property name="password" value="123"></property>
</bean> </beans>

注意:如果新建一个userDao类去访问数据库的话,由于在访问时需要jdbcTemplate对象

  JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);

所以,还需要在配置文件中把创建jdbcTemplate的对象配置配好,并注入dataSource属性。

 数据库的事务管理

  spring 为不同的持久化框架提供了不同的事务管理器的接口,共有以下几种类型

  1)org.springframework.jdbc.datasource.DataSourceTransactionManager  -- 用spring jdbc或ibatis进行持久化时用

  2)org.springframework.orm.hibernate5.HibernateTransactionManager  --用于hibernate5版本

  3)org.springframework.orm.jpa.jpaTransactionManager  --用于jpa持久化

  4)org.springframework.transaction.jta.jtaTransactionManager  --JTA管理事务时,在一个事务跨越多个资源时必须使用

  在进行数据库修改操作时,经常被谈及到事务这个概念,那什么叫事务呢?事务就是指一系列的数据库操作的组合,单次对数据表的增删改查为一次操作,只有事务中所有的操作指令全部执行成功,事务才算成功,否则就算失败;如果事务失败,则在事务中已经成功的操作,统统执行回滚操作至事务执行前的状态。

  为什么事务失败需要回滚,就拿举例最多的银行转帐事件来作为例子吧。

  在转帐过程中,A向B转1000元,首先系统从帐户表里用户A的account里的钱减去1000元,再给B的account里加上1000元,至此整个转帐事务成功。但是在A的account里减去1000成功后,在往B帐号里执行增加1000元的操作时,系统异常退出了,你会发现,A的钱扣了,但是B却没有增加,为了保证数据的一致性,必须将恢复到扣钱前的状态,这就是回滚。事务与回滚就是为了保证数据的一致性。

  在spring中,使用AOP的技术将事务管理切入到对数据库操作的dao层方法中,就将dao层中的方法用事务管理起来,如果在dao层中方法一旦有异常抛出,事务会自动让数据库进行回滚操作。配置文件参见如下

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd"> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql:///dbname"></property>
<property name="user" value="root"></property>
<property name="password" value="123"></property>
</bean> <!--第一步 配置事务管理-->
<bean id="transactionMgr" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!--第二步 配置事务增强,使用AOP技术将事务管理添加到dao层-->
<tx:advice id="txadvice" transaction-manager="transactionMgr">
<tx:attributes>
<!--name 表达式表示 所有save开头的方法需要事务操作;
propagation 表示隔离级别-->
<tx:method name="save*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
<!--第三步 配置切面-->
<aop:config>
<aop:pointcut id="pointcutdb" expression="execution(* com.blueto.*(..))"/>
<!--切面-->
<aop:advisor advice-ref="txadvice" pointcut-ref="pointcutdb"/>
</aop:config> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"></property>
</bean>
</beans>

  --注解方式添加事务管理

  相对于上一种方式,注解方式要简单一些,在配置文件中只需要两步

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd"> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql:///dbname"></property>
<property name="user" value="root"></property>
<property name="password" value="123"></property>
</bean> <!--第一步 配置事务管理-->
<bean id="transactionMgr" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!--第二步 开户事务注解-->
<tx:annotation-driven transaction-manager="transactionMgr"/>

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"></property>
</bean>
</beans>

  在需要使用事务管理的方法所在类前,添加上注解@Transtional即可。

@Transactional
public class UserDao {
public void add() {
System.out.print("在这里添加一个用户");
}
}

spring学习之三 数据库操作jdbcTemplate的更多相关文章

  1. PHP学习之-数据库操作

    PHP学习之-数据库操作 1.PHP支持那些数据库 PHP通过安装相应的扩展来实现数据库操作,现代应用程序的设计离不开数据库的应用,当前主流的数据库有MsSQL,MySQL,Sybase,Db2,Or ...

  2. java EE学习之数据库操作

    jdbc开发流程 注册驱动 建立连接(Connection) 创建运行SQL的语句(Statement) 运行语句 处理运行结果(ResultSet) 释放资源 注冊驱动有三种方式: Class.fo ...

  3. ThinkPHP5.1学习笔记 数据库操作

    数据库 参见<Thinkphp5.1完全开发手册>学习 Mirror王宇阳 数据库连接 ThinkPHP采用内置抽象层对数据库操作进行封装处理:且基于PDO模式,可以适配各种数据库. 数据 ...

  4. PHP学习之数据库操作

    PHP数据库操作: 一.连接数据库 mysql_connect() 例:$link=mysql_connent("localhost","root"," ...

  5. spring框架学习之--数据库操作增删改查

    基于spring的NamedParameterJdbcTemplate操作数据库 首先在 resources 文件夹下添加数据库配置文件jdbc.properties 配置常用的数据库信息 consu ...

  6. spring学习笔记---数据库事务并发与锁详解

    多事务运行并发问题 在实际应用中,往往是一台(或多台)服务器向无数客户程序提供服务,当服务器查询数据库获取数据时,如果没有采用必要的隔离机制,可能会存在数据库事务的并发问题,下面是一些常见的并发问题分 ...

  7. 多事务运行并发问题spring学习笔记——数据库事务并发与锁详解

    多事务运行并发问题 在实际应用中,往往是一台(或多台)服务器向无数客户程序提供服务,当服务器查询数据库获取数据时,如果没有采用必要的隔离机制,可能会存在数据库事务的并发问题,下面是一些常见的并发问题分 ...

  8. 一、javase学习:数据库操作练习

    package JDBC_TEST; import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLExcept ...

  9. JavaEE学习笔记---数据库操作篇

    测试JDBC和SQLServer的插入操作,源码如下: import java.sql.Connection;import java.sql.DriverManager;import java.sql ...

随机推荐

  1. codevs2875RY哥查字典

    题目链接:http://codevs.cn/problem/2875/ 题目描述 Description RY哥最近新买了一本字典,他十分高兴,因为这上面的单词都十分的和谐,他天天查字典. 输入描述 ...

  2. 【BZOJ4205】卡牌配对

    Description 现在有一种卡牌游戏,每张卡牌上有三个属性值:A,B,C.把卡牌分为X,Y两类,分别有n1,n2张. 两张卡牌能够配对,当且仅当,存在至多一项属性值使得两张卡牌该项属性值互质,且 ...

  3. 使用cmstp绕过应用程序白名单

    默认情况下,AppLocker允许在文件夹中执行二进制文件,这是可以绕过它的主要原因.已经发现,这样的二进制文件可以很容易地用于绕过AppLocker和UAC.与Microsoft相关的二进制文件之一 ...

  4. sqlmap利用DNS进行oob(out of band)注入(转)

      0x00 起因 实际案子的时候遇到了一个注入,过狗可以使用sqlmap,但是是基于时间的注入和限制频率需要使用--delay参数,本来就是延时再加上--delay等的心力憔悴.所有有了下面介绍使用 ...

  5. Bypass AV meterpreter免杀技巧

    0x01 meterpreter简介 MetasploitFramework是一个缓冲区溢出测试使用的辅助工具,也可以说是一个漏洞利用和测试平台,它集成了各种平台上常见的溢出漏洞和流行的shellco ...

  6. POJ.1330 Nearest Common Ancestors (LCA 倍增)

    POJ.1330 Nearest Common Ancestors (LCA 倍增) 题意分析 给出一棵树,树上有n个点(n-1)条边,n-1个父子的边的关系a-b.接下来给出xy,求出xy的lca节 ...

  7. Java之Java程序与虚拟机

    Java为什么要在虚拟机中运行 简单的来说,Java作为一门高级程序语言,语法复杂,抽象度高,不能直接翻译为机器码在机器上运行,所以设计者就设计了虚拟机,通过编译器将Java程序转换成虚拟机所能识别的 ...

  8. as, idea 出现 Gradle's dependency cache may be corrupt 错误分析

    问题: Error:Failed to open zip file.Gradle's dependency cache may be corrupt (this sometimes occurs af ...

  9. (转)Tomcat version 7.0 only supports J2EE 1.2, 1.3, 1.4, and Java EE 5 and 6 Web mod

    背景:在sts中导入web项目,却不能通过sts中的tomcat来加载该服务,并报出如下错误. “Tomcat version 7.0 only supports J2EE 1.2, 1.3, 1.4 ...

  10. C#线程篇---Windows调度线程准则(3)

    Windows本身就是一个抢占式操作系统,它的实现,必定有某种算法在里面,比如什么时候调度哪些线程,需要花费多长时间等问题. 我们时时在用Windows,作为程序员,我们有必要知道其中最贴近我们的算法 ...