A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

【郑州校区】JavaEE三大框架课堂笔记之Spring-day10

基于annotation方案
第一步:编写目标
在spring的配置文件中配置扫描注解
第二步:编写增强(advice)
使用@Aspect来声明切面
使用@Before来声明前置通知
注意:必须在spring的配置文件中开启aspectJ注解自动代理功能。
第三步:测试
其它通知类型及参数
后置通知
环绕通知
异常抛出通知
最终通知
使用@Pointcut注解定义切点
在每一个通知中定义切点,工作量大,不方便维护,我们可以使用@Pointcut来声明切点
切点允许逻辑运算例如mypointcut()||mypointcut1
关于代理方式选择
Proxy-target-class默认值是false,代表的是如果目标是有接口的使用proxy代理,如果没有接口使用cglib.
如果将proxy-target-class=true,不管目标是否有接口,都会使用cglib进行代理。
Spring jdbc Template
Spring提供了一个jdbc模板,它类似于dbutils工具。
问题:如何使用spring jdbc template?
第一:要导入相关的jar包
        在这个基础上我们还需要导入
        还需要导入相关的数据库驱动jar包。
第二:spring jdbc template快速入门
快速入门
第一步:导入相关jar包,创建了一个JdbcTemplateTest1测试类
第二步:创建库与表
[AppleScript] 纯文本查看 复制代码
CREATE DATABASE springtest;[/size][/font][/align][font=微软雅黑][size=3]
USE springtest;

CREATE TABLE t_user(
        
        id INT PRIMARY KEY AUTO_INCREMENT,
        NAME VARCHAR(20),
        age INT,
        sex VARCHAR(20)
)

INSERT INTO t_user VALUES(NULL,'tom',20,'男');
INSERT INTO t_user VALUES(NULL,'fox',30,'男');
INSERT INTO t_user VALUES(NULL,'tony',40,'男');

SELECT * FROM t_user;
第三步:编码
配置spring内置的连接池DriverManagerDataSource
C3P0开源连接池配置
1. 导入c3p0相关的jar包
2. 创建一个ComboPoolDataSource对象,设置相关的属性
引入外部属性文件
Spring支持将经常修改属性,在properties文件中声明,在xml配置文件中引入外部的properties文件的信息。
在applicationContext.xml文件中引入
在自己配置中需要从properties文件中引入的信息可以使用${name}方式来获取
JdbcTemplate CRUD执行insert update delete操作
只需要使用JdbcTemplate的update方法就可以执行insert update delete操作
执行select操作简单数据返回
复杂数据返回
注意:如果只返回一个domain对象,可以使用queryForObject方法,如果返回的是List<?>对象,可以使用query方法,但是都需要使用RowMapper来对ResultSet进行处理。
RowMapper它有一个实现类叫BeanPropertyRowMapper
如果使用BeanPropertyRowmapper,实体类必须提供一个无参数的public构造方法,类中的bean属性名称与表中的列要对应
注意:这个类是在spring2.5后提供。
Spring 事务管理案例转账操作创建一个关于帐户表
[AppleScript] 纯文本查看 复制代码
CREATE TABLE account(
        id INT PRIMARY KEY AUTO_INCREMENT,
        NAME VARCHAR(20),
        money DOUBLE
)

INSERT INTO account VALUES(NULL,'tom',1000);
INSERT INTO account VALUES(NULL,'fox',1000);

创建service与dao
对于数据的操作使用spring jdbc template
关于service与dao的配置
我们让dao去extends JdbcDaoSupport类,这个类中它创建了JdbcTempate,前提是我们需要注入一个dataSource.
在dao中在获取JdbcTemplate可以使用父类提供的getJdbcTemplate方法来获取。
转账操作的问题
如果在转账操作过程中出现问题,那么转账会出现问题,结果如下
也就是我们程序需要事务控制。



传智播客·黑马程序员郑州校区地址
河南省郑州市 高新区长椿路11号大学科技园(西区)东门8号楼三层
联系电话 0371-56061160/61/62
来校路线  地铁一号线梧桐街站A口出


2 个回复

倒序浏览
回复 使用道具 举报
{:8_507:}
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马