JdbcTemplate:用于操作数据库,与Dbutils一样,是一个操作数据库的工具。
首先声明事物是很简单的,只是为了展现例子,需要做很多准备工作。
1)使用c3p0获取连接:
先导入mysql的jar包: mysql-connector-java-8.0.16.jar
再导入c3p0的3个jar包: c3p0-0.9.5.2.jar c3p0-oracle-thin-extras-0.9.5.2.jar mchange-commons-java-0.2.11.jar
下载地址:https://sourceforge.net/projects/c3p0/files/latest/download?source=files ——等待一会自动弹出下载框
c3p0的基础知识:https://www.cnblogs.com/ygj0930/p/6405861.html
2)创建配置文件:
先创建:db.properties https://blog.csdn.net/u013164931/article/details/76283884
jdbc.user=root
jdbc.pssward=123456
jdbc.driverClass=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT
jdbc.initPoolSize=5
jdbc.maxPoolSize=10
配置xml文件
class="com.mchange.v2.c3p0.ComboPooledDataSource">
这个时候要记得测试资源配置有没有问题
3)配置JdbcTemplate
这个时候要记得测试
4)事物的准备工作:
数据库:
CREATE TABLE `student`.`book` (
`isbn` VARCHAR(50) NOT NULL,
`book_name` VARCHAR(100) NULL,
`price` INT NULL,
PRIMARY KEY (`isbn`));
CREATE TABLE `student`.`book_stock` (
`isbn` VARCHAR(50) NOT NULL,
`stock` INT NULL,
PRIMARY KEY (`isbn`));
CREATE TABLE `student`.`account` (
`username` VARCHAR(50) NOT NULL,
`balance` INT NULL,
PRIMARY KEY (`username`));
基本的方法:
代码不贴了。。。
5)声明式事务: XML配置文件,配置两个
注:启用事务注解的资源头文件为xmlns:tx="http://www.springframework.org/schema/tx"
在要启用事务的方法前面@Transactional写上注解
//在方法写注解,启用事务
@Transactional
@Override
public void purchase(String username, String isbn) {
//1获取书的单价
int price=bookShopDao.findBookPriceByIsbn(isbn);
//2更新库存
bookShopDao.updateBookStock(isbn);
//3 更新账号余额
bookShopDao.updateUserAccunt(username,price);
}