spring整合JDBC

spring提供了很多模板整合Dao技术

spring中提供了一个可以操作数据库的对象.对象封装了jdbc技术.

JDBCTemplate => JDBC模板对象   与DBUtils中的QueryRunner非常相似

使用步骤

导包

4+2

spring-test

spring-aop以前不需要

junit4类库

c3p0连接池

--------新的--------------

JDBC驱动

spring-jdbc

spring-tx事务

准备数据库        准备Dao

增删改

查询  值类型 / 引用类型 /集合类型

spring配置

依赖关系

测试

首先在spring配置文件中不进行任何配置

使用jdbc模板进行操作

public void fun1() throws Exception{
//0 准备连接池
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setDriverClass("com.mysql.jdbc.Driver");
dataSource.setJdbcUrl("jdbc:mysql:///hibernate_32");
dataSource.setUser("root");
dataSource.setPassword("1234");
//1 创建JDBC模板对象
JdbcTemplate jt = new JdbcTemplate();
jt.setDataSource(dataSource);
//2 书写sql,并执行
String sql = "insert into t_user values(null,'rose') ";
jt.update(sql);
}

在userDao里面自动注入 JdbcTempate 属性

<context:property-placeholder location="classpath:db.properties"/>
<!-- 配置数据库连接池 -->
<bean name="data" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
<property name="driverClass" value="${jdbc.driverClass}"></property>
<property name="user" value="${jdbc.user}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean> <!-- 将 jdbcTemplate需要的 连接池注入进来 -->
<bean class="org.springframework.jdbc.core.JdbcTemplate" name="template">
<property name="dataSource" ref="data"></property>
</bean> <bean name="userDao" class="com.myjdbc.UserDao">
<property name="jt" ref="template"></property>
</bean>

思路:JdbcTemplate 里面注入 连接池   UserDao里面注入 JdbcTemplate对象

注意:属性名称要一致 还有就是 里面UserDao里面要有 getter 和 setter 方法  否则不能成功

public class UserDao implements IUserDao{

    private JdbcTemplate jt;public JdbcTemplate getJt() {
return jt;
}
public void setJt(JdbcTemplate jt) {
this.jt = jt;
} @Override
public void delete(int id) {
System.out.println("调用了 delete 方法");
String sql = "delete from t_student where sId = ?";
int i = jt.update(sql,id);
System.out.println(i);
}
}

可以看出 UserDao里面比较乱   因为有 JdbcTemplate的getter 和 setter方法

怎么解决?

可以使用:UserDao继承  JdbcSupport

配置文件如下:

<context:property-placeholder location="classpath:db.properties"/>
<!-- 配置数据库连接池 -->
<bean name="data" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
<property name="driverClass" value="${jdbc.driverClass}"></property>
<property name="user" value="${jdbc.user}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean> <bean name="userDao" class="com.myjdbc.UserDao">
<property name="dataSource" ref="data"></property>
</bean>

这样在 就可以不用配置 JdbcTemplate 对象了  只需要在UserDao里面注入 连接池对象即可(dataSource)

public class UserDao extends JdbcDaoSupport implements IUserDao{
@Override
public void delete(int id) {
System.out.println("调用了 delete 方法");
String sql = "delete from t_student where sId = ?";
int i = super.getJdbcTemplate().update(sql, id);
System.out.println(i);
}
}

DBCDaoSupport的使用     该对象是 根据连接池创建 JDBC 模板

不需要手动准备JDBC模板  从父类方法中获得即可

注意加前缀,避免出现相同的属性

spring中aop事务

事务

事务并发问题  脏读 不可重复读 幻读

事务的隔离级别

1 读未提交

  2 读已提交

  4 可重复读

  8 串行化

spring中封装了事务管理代码

事务操作对象

因为在不同平台,操作事务的代码各不相同.spring提供了一个接口

PlatformTransactionManager 接口 针对不同平台提供不同的类

DataSourceTransactionManager

HibernateTransitionmanager

注意:在spring中玩事务管理.最为核心的对象就是TransactionManager对象

spring管理事务的属性介绍    是否只读 true 只读、false 可操作

事务的传播行为:决定业务方法之间的调用,事务应该如何处理  默认 使用第一个

spring管理事务方式

编码式(了解)

1.将核心事务管理器配置到spring容器

2.配置TransactionTemplate模板

3.将事务模板注入Service

4.在Service中调用模板

xml配置(aop)的方式

1.导包  aop  Aspect   aop联盟   weaving织入包

2.导入新的约束(tx)   xml约束

beans:最基本的      context:读取properties配置文件的  aop:配置AOP的       tx:配置事务通知的

3.配置通知

4.配置将通知织入目标

注解配置(aop)的方式

3.开启注解管理事务

4.使用注解

补充:

一个业务的成功: 调用的service是执行成功的,意味着service中调用的所有的dao是执行成功的。  事务应该在Service层统一控制。

引入外部文件

spring学习3的更多相关文章

  1. spring 学习之 bean 的注入方式 property和constructor-arg的使用方式

    spring 学习之 bean 的注入方式 property和constructor-arg的使用方式. bean的注入方式: property 注入是: 通过setxx方法注入. construct ...

  2. Spring学习之AOP总结帖

    AOP(面向方面编程),也可称为面向切面编程,是一种编程范式,提供从另一个角度来考虑程序结构从而完善面向对象编程(OOP). 在进行 OOP 开发时,都是基于对组件(比如类)进行开发,然后对组件进行组 ...

  3. Spring学习之第一个AOP程序

    IOC和AOP是Spring的两大基石,AOP(面向方面编程),也可称为面向切面编程,是一种编程范式,提供从另一个角度来考虑程序结构从而完善面向对象编程(OOP). 在进行 OOP 开发时,都是基于对 ...

  4. MyEclipse Spring 学习总结三 SpringMVC

    MyEclipse Spring 学习总结三 SpringMVC 一.SpringMVC原理 1.Springmvc 框架介绍 1)Spring 框架停工了构建Web应用程序的全功能MVC模块.Spr ...

  5. Spring学习 Ioc篇(一 )

    一直以来忙于项目的开发,Spring虽然不用,一直想系统地学习一下,想看看它的源码,都没有时间,这段时间比较充裕,就索性先把Spring学习下,熟悉各个功能再去探究它内部的实现.就从Ioc篇开始学习. ...

  6. Spring学习(三)——Spring中的依赖注入的方式

    [前面的话] Spring对我太重要了,做个关于web相关的项目都要使用Spring,每次去看Spring相关的知识,总是感觉一知半解,没有很好的系统去学习一下,现在抽点时间学习一下Spring.不知 ...

  7. Spring学习(二)——Spring中的AOP的初步理解[转]

      [前面的话] Spring对我太重要了,做个关于web相关的项目都要使用Spring,每次去看Spring相关的知识,总是感觉一知半解,没有很好的系统去学习一下,现在抽点时间学习一下Spring. ...

  8. 【Spring学习笔记-MVC-3.1】SpringMVC返回Json数据-方式1-扩展

    <Spring学习笔记-MVC>系列文章,讲解返回json数据的文章共有3篇,分别为: [Spring学习笔记-MVC-3]SpringMVC返回Json数据-方式1:http://www ...

  9. Spring学习8-Spring事务管理

      http://blog.sina.com.cn/s/blog_7ffb8dd501014e0f.html   Spring学习8-Spring事务管理(注解式声明事务管理) 标签: spring注 ...

  10. Spring学习之Ioc控制反转(1)

    开始之前: 1. 本博文为原创,转载请注明出处 2. 作者非计算机科班出身,如有错误,请多指正 ---------------------------------------------------- ...

随机推荐

  1. SQLAIchemy 学习(一)Session 相关

    0. 前言 最近是使用 SQLAlchemy 框架作为一个 ORM 框架,现对其做简单整理 1. 创建 Session 说到数据库,就离不开 Session.Session 的主要目的是建立与数据库的 ...

  2. SpringBoot第十篇:thymeleaf详解

    作者:追梦1819 原文:https://www.cnblogs.com/yanfei1819/p/10931435.html 版权声明:本文为博主原创文章,转载请附上博文链接! 引言   Sprin ...

  3. CentOS7安装图形化界面方法

    一.linux安装(root用户操作) 1. 安装vncserver; yum install tigervnc-server 2. 安装vncviewer; yum install vnc 3. 设 ...

  4. 明解C语言 入门篇 第十章答案

    练习10-1 #include <stdio.h> void adjust_point(int*n) { ) *n = ; ) *n = 0; } int main() { int x; ...

  5. maven打包产生可执行jar包

    http://blog.csdn.net/u014695188/article/details/53128095 https://blog.csdn.net/fuck487/article/detai ...

  6. KVM学习

    获取镜像目前大小 # qemu-img info debian.img 添加额外的10G空间到镜像中 # qemu-img resize -f raw debian.img +10GB 注意:并不是所 ...

  7. 【转】Redis 分布式锁的正确实现方式( Java 版 )

    链接:wudashan.cn/2017/10/23/Redis-Distributed-Lock-Implement/ 前言 分布式锁一般有三种实现方式:1. 数据库乐观锁:2. 基于Redis的分布 ...

  8. java报错 pom.xml第一行报"org.apache.maven.archiver.MavenArchiver.getManifest(org.apache.maven.project...

    https://www.cnblogs.com/appium/p/11168441.html 新建Maven项目时,每个pom文件第一行都报错. 一.问题分析 原因就是你的maven的配置文件不是最新 ...

  9. 北理工机器人队RM视觉组学习参考汇总(持续更新中)

    欢迎大家有意加入北理工机器人队参与到视觉组的工作中.在大家能够正式作为队员参与到视觉组的准备工作之前,北理机器人队需要对各位进行培训.这篇文章主要面向有志于参加机器人队视觉组的同学.同时,欢迎所有对相 ...

  10. Java常用框架和软件