Spring-day03
Spring集成JDBC:提供了一些方便我们使用JDBC的工具类;
query(String,ResultSetHandler handler,Object..parm){
Connection connect=dataSource.getConnection();
connect.preparedStatement();
for(){
ps.setObject();
}
ResultSet rs=ps.executeQuery();
List ret=handler.handle(rs);
return ret;
} update(String sql,Object..param){
Connection connect=dataSource.getConnection();
connect.preparedStatement();
for(){
ps.setObject();
}
int rs=ps.executeUpdate();
return rs;
}
1,在Spring中,主要使用JDBCTemplate来完成我们的JDBC代码;
2,使用SpringJDBC
1),在Spring中配置一个dataSource;
2),完成DAO:
1),dao中需要一个jdbcTemplate对象;
2),不需要setJdbcTemplate,而是使用setDataSource;用传入的dataSource去new JdbcTemplate(dataSource);
3),使用jdbcTemplate上的方法来完成JDBC代码;
4),jdbcTemplate.update(String,Object..params):一般用来DML;
5),jdbcTemplate.query(String,ResultSetExtractor/RowMapper,Object..parmas):一般用来查询;
1,ResultSetExtractor:需要自己手动遍历结果集;
2,RowMapper:spring榜我们遍历结果集,我们只需要在这个对象中映射每一行数据;
SpringJDBC补充:
1,Spring提供了JdbcDaoSupport类,在这个类里面帮我们封装了jdbcTemplate的创建过程,我们的DAO只需要继承JdbcDaoSupport类,就可以了,
1),使用this.getJdbcTemplate()获得jdbcTemplate;
2),在Spring配置文件中,还是要为dao设置dataSource:
2,使用占位符的方式 把数据库连接信息放到额外的配置文件中;
1),把xml配置文件中的值改成类似EL表达式的方式,
2),创建一个配置文件x.properties,要求,properties文件中的key值需要和spring中配置的占位符的名字匹配
3),在XML配置文件中导入占位符配置文件;
<!-- 配置连接池 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
<property name="driverClassName" value="${db.driverClassName}"/>
<property name="url" value="${db.url}"/>
<property name="username" value="${db.username}"/>
<property name="password" value="${db.password}"/>
</bean>
<!-- 导入占位符配置文件${jdbc.xxx}
location:配置文件地址,可以使用前缀
-->
<context:property-placeholder location="classpath:db.properties"/>
//db.properties
#key=value
db.driverClassName=com.mysql.jdbc.Driver
db.url=jdbc:mysql://localhost:3306/spring
db.username=root
db.password=admin
3,spring配置文件的继承;
1),抽象的类是不能直接配置在spring中的,需要在bean元素上面添加abtract=true属性;
2),子类要继承父类的配置,必须要在bean元素上面添加parent属性,指向父bean的引用;
3),在spring配置文件中,其实是没有继承的概念;
1,一个bean是可以不需要class属性的,但是如果一个bean没有class属性,那么一定要添加abstract=true;代表这个bean是不需要去实例化的,这个bean是用来给其他的配置文件做继承的;
2,parent属性并不是代表对象的继承关系,它代表的是配置文件的拷贝;
<!-- 不能实例化的对象想配置在Spring里面,
abstract="true":代表这个类是抽象的,不用实例化
因为这个bean不需要实例化,所以不用编写class属性
-->
<bean id="baseDAO" abstract="true">
<property name="dataSource" ref="dataSource"></property>
</bean> <!-- 在子类中要配置parent属性,指向父类bean的引用 -->
<bean id="employeeDAO" class="com.rk1632._01_jdbc.EmployeeDAOImpl" parent="baseDAO"/> <!-- 在子类中要配置parent属性,指向父类bean的引用 -->
<bean id="deptDAO" class="com.rk1632._01_jdbc.DepartmentDAOImpl" parent="baseDAO"/>
Spring中事务的管理:
1,事务要开在service上;
2,PlatformTranscationManager:Spring中的事务管理器;
1),TransactionStatus getTransaction():开启事务;
2),void commit(TransactionStatus status):提交事务;
3),void rollback(TransactionStatus status):回滚事务;
3,TransactionStatus:可以简单理解为创建的事务对象;
4,Spring中提供的常用的事务管理器;
我们需要注意的:
1),DataSourceTranscationManager:针对JDBC;
2),HibernateTranscationManager:针对Hibernate(版本);
3),JpaTransactionManager:针对JPA;
spring管理事务:
1,配置一个和我们的持久化方式匹配的事务管理器;
<!-- 配置事务管理器 -->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
2,因为我们使用的是JDBC,所以选择DataSourceTranscationManager;
1),在这个txManager中一定要传入一个DataSource;
2),由这个dataSource来得到连接,管理事务;
3),注意,这个传入的dataSource已经被spring代理过了,在调用getConnection的时候,实际上得到的是当前线程中的Connection;
3,配置事务
1),配置datasource
2),配置baseDAO和transactionManager(使用同一个datasource);
3),配置service;
4),配置事务通知(tx:advice)
1),名字(id):被切面引用;
2),transaction-manager:在事务通知中,真正的执行开启事务,提交事务,回滚;
3),配置事务属性:控制拦截到的不同的方法,具体怎么处理事务
5),配置aop:
1),配置切入点(aop:point-cut);
2),配置aop:advisor(pointCut-ref/advice-ref)(把通知和切入点连起来)
配置事务属性:
1,tx:method是从上向下匹配的,一般最后一个tx:method的name="*",用来匹配上面方法匹配不到的其他方法的事务处理方式;
2,read-only:开启一个只读的事务,只读的事务性能较高,不能在只读的事务中做DML操作;
3,isolation:隔离级别
1),DEFAULT:使用数据库默认的隔离级别;
2),注意,这个属性一般填写为DEFAULT(默认),这个事务隔离级别是spring模拟出来;
4,rollback-for:遇到什么异常事务要回滚(默认情况下,spring只有遇到RuntimeException才会回滚);
5,propagation:事务的传播方式(默认是REQUIRED);
1),常用:REQUIRED,REQUIRES_NEW;
2),一般来说,tx:method最后一个方法都写作REQUIRED
使用Annotation配置事务:
1,在service方法或者类上面添加@Transactional标签;
1),如果在类上面,相当于为类中的所有方法创建了一个默认的事务控制方式;
2),如果要覆盖掉默认的方式,只需要在方法上面再重新写一次@Transactional
2,在spring的配置文件中,使用<tx:annotation-drivern>标签来引入用于解析@Transactional标签的第三方应用;
选择:建议使用配置文件的方式;
Spring-day03的更多相关文章
- Spring day03笔记
spring day02回顾 AOP :切面编程 切面:切入点 和 通知 结合 spring aop 编程 <aop:config> 方法1: <aop:pointcut expre ...
- 开放源代码的设计层面框架Spring——day03
spring第三天 一.AOP的相关概念 1.1AOP概述 1.1.1什么是AOP AOP:全称是Aspext Orie ...
- Spring day04笔记(SVN讲解和回顾昨天知识)
spring day03回顾 事务管理 基于xml配置 1.配置事务管理器 jdbc:DataSourceTransactionManager hibernate:HibernateTransacti ...
- Spring day01笔记
struts:web层,比较简单(ValueStack值栈,拦截器) hibernate:dao层,知识点杂 spring:service层,重要,讲多少用多少 --> [了解] sprin ...
- spring框架入门day01
struts:web层,比较简单(ValueStack值栈,拦截器) hibernate:dao层,知识点杂 spring:service层,重要,讲多少用多少 --> [了解] spring ...
- Spring-Day03-注解注入&AOP入门-作业
IOC(DI) —— 注解 注解入门: 在applicationContext.xml中引入context约束 打开spring-framework-4.2.4.RELEASE\docs\spring ...
- Spring Boot 注解配置 day03
一.SpringBoot注解 @PropertySource 和 @ImportResource和@Bean 1.@PropertySource 加载指定位置的配置文件(只能是properties文件 ...
- 传智播客JavaWeb day03
ServletContext 这堂课主要讲ServletContext这个web域(可以看得见范围的)对象,web在启动的时候会创建唯一的ServletContext域对象. 作用:1.用来web域共 ...
- SSM-Spring-02:Spring的DI初步加俩个实例
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- DI:依赖注入 第一个DEMO:域属性注入 java类:(Car类和Stu类,学生有一辆小汽车) packag ...
- 课程5:Spring框架2016版视频--视频列表目录
\day01视频\01-今天内容介绍.avi; \day01视频\02-spring的相关概念.avi; \day01视频\03-spring的ioc底层原理(一).avi; \day01视频\04- ...
随机推荐
- nginx php程序 文件上传大小限制
关于 PHP 程序上传限制 更改 php.ini 配置文件 upload_max_filesize = 5M post_max_size = 16M 通过 nginx 环境限制上传大小: 可以在 ht ...
- DeepLearning.ai学习笔记(五)序列模型 -- week2 自然语言处理与词嵌入
一.词汇表征 首先回顾一下之前介绍的单词表示方法,即one hot表示法. 如下图示,"Man"这个单词可以用 \(O_{5391}\) 表示,其中O表示One_hot.其他单词同 ...
- $Django 路飞之显示视频,Redis存购物车数据,优惠卷生成表,优惠卷的一个领取表。(知识小回顾)
知识小回顾之json序列化问题 精髓:支持python的几种数据类型(注意不是对象,不能放对象),其次是tuple变list. ensure_ascii:默认值True,如果dict内含有non-AS ...
- Mysql --数据库概述1
什么是数据(Data)? 描述事物的符号记录称为数据,描述事物的符号既可以是数字,也可以是文字.图片,图像.声音.语言等,数据由多种表现形式,它们都可以经过数字化后存入计算机 在计算机中描述一个事物, ...
- ng2-translate 国际化中 配置文件添加变量
1. <li> {{ 'Withdrawmoney.tipsP1' | translate:{value:assets} }} </li> 2. "Withdrawm ...
- Set集合(scala)
特点 Set集合最大的特点是:无序 不可重复 定长Set集合 无序 scala> val set = Set(1,5,4,3,7) set: scala.collection.immutable ...
- hash与encrypt
概括来说,哈希(Hash)是将目标文本转换成具有相同长度的.不可逆的杂凑字符串(或叫做消息摘要),而加密(Encrypt)是将目标文本转换成具有不同长度的.可逆的密文. 具体来说,两者有如下重要区别: ...
- Ubuntu-linux云服务器下安装开启虚拟环境失败解决办法
为什么要安装虚拟环境? 1.某些项目需要安装旧的包,开发相应功能 2.项目开发时,安装部分环境不希望影响整机环境 如何安装? 首先安装python 安装pip工具 sudo apt-get insta ...
- 在Windows环境下搭建Nginx文件服务器(简单实用版)
为了解决项目组内容应用,打算把本地的e:tools目录共享出来,具体操作步骤如下1.下载安装包:http://nginx.org/download/nginx-1.9.15.zip2.解压缩3.修改配 ...
- MySql+EF <二>
C#使用Mysql+EF架构项目有一系列问题. 一.EF没有Mysql的驱动,这个需要自己安装2个插件 ①mysql-connector-net-6.9.10.msi ②mysql-for-visua ...