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. 开源组件websocket-sharp中基于webapi的httpserver使用体验

    一.背景 因为需要做金蝶ERP的二次开发,金蝶ERP的开放性真是不错,但是二次开发金蝶一般使用引用BOS.dll的方式,这个dll对newtonsoft.json.dll这个库是强引用,必须要用4.0 ...

  2. c# 在DataTable的第一列(指定列)的前面添加一列

    c# 在DataTable的第一列(指定列)的前面添加一列 dt.Columns.Add("ID").SetOrdinal(0)  

  3. visual studio -- 调试时自动传递给exe入参

    如果你写的main函数接受入参int main(int argc, char* argv[]),则可以 右键工程--属性--调试,在命令行参数中输入入参即可,这些字符串会被直接传递给exe.

  4. 详解XOR(异或)运算加密

    逻辑运算之中,除了 AND 和 OR,还有一种 XOR 运算,中文称为"异或运算".它的定义是:两个值相同时,返回false,否则返回true.也就是说,XOR可以用来判断两个值是 ...

  5. pytest_demo_实战1

    1.根目录配置 pytest.ini [pytest] addopts = -p no:warnings 2.更改运行手势,系统配置 file -> setting -> Tools -& ...

  6. 五、Hexo静态博客背景及界面显示优化配置

    示例预览:我的主页 背景图片添加 自动切换背景 静态本地背景 首先将已选定的背景图片放到博客根目录下的\source\images下 ​ 示例:D:\Blog\source\images\backgr ...

  7. nginx 配置反向代理,负载均衡实战解析

    前言:NGINX的反向代理和负载均衡是网站架构中经常用到的一种高并发,高可用的方案,下面我们直接实战操作,当然理论也是要的. 一.反向代理 过程:反向代理:客户端 一>代理 <一> ...

  8. 初始认知学习 .net core 逐步加深

    1.一般用空项目练手 2.一般你已经有数据库的情况下使用如下的方式 开始生成类的操作 这里我使用的是Database First模式,使用工具Scaffold-DbContext(数据库上下文脚手架) ...

  9. 解决Laydate在弹出层中一闪而过的问题

    解决办法:添加 trigger: 'click' 属性 laydate.render({ elem: '#demo' ,btns: ['clear', 'now'] ,trigger: 'click' ...

  10. Vuex实现状态管理

    Vuex使用总结 1 Vuex简介 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式,Vuex抽取了各个组件的共享部分,以全局单例模式进行状态的管理.在原生vue中各个组件之间传值使用的 ...