Spring注解开发——6. 声明式事务

本文详细介绍了如何在Spring框架下使用JDBC进行数据库操作,并通过配置数据源、JdbcTemplate及事务管理器实现对数据库的高效操作与事务控制。通过具体代码示例,展示了如何创建配置类、业务测试类和服务类,以及如何在业务类上添加事务控制注解。

1 环境准备

1.1 添加相关依赖

1)数据源

2)数据库驱动

3)spring-jdbc模块

<dependency>
	<groupId>org.springframework</groupId>
	<artifactId>spring-jdbc</artifactId>
	<version>4.3.12.RELEASE</version>
</dependency>
<dependency>
	<groupId>c3p0</groupId>
	<artifactId>c3p0</artifactId>
	<version>0.9.1.2</version>
</dependency>

<dependency>
	<groupId>mysql</groupId>
	<artifactId>mysql-connector-java</artifactId>
	<version>5.1.44</version>
</dependency>

1.2 配置数据源和JdbcTemplate操作数据库

package com.bjc.config;

import javax.sql.DataSource;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.jdbc.core.JdbcTemplate;

import com.mchange.v2.c3p0.ComboPooledDataSource;

@Configuration
@ComponentScan(basePackages = {"com.bjc"})
public class TxConfig {
	//数据源
	@Bean
	public DataSource dataSource() throws Exception{
		ComboPooledDataSource dataSource = new ComboPooledDataSource();
		dataSource.setUser("root");
		dataSource.setPassword("root");
		dataSource.setDriverClass("com.mysql.jdbc.Driver");
		dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/test");
		return dataSource;
	}
	
	// JdbcTemplate
	@Bean
	public JdbcTemplate jdbcTemplate() throws Exception{
		//Spring对@Configuration类会特殊处理;给容器中加组件的方法,多次调用都只是从容器中找组件
		JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource());
		return jdbcTemplate;
	}
}

1.3 业务测试类

1)service

package com.bjc.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.bjc.dao.UserDao;

@Service
public class UserService {
	@Autowired
	private UserDao userDao;
	public void save() {
		userDao.save();
		System.out.println("插入完成。。");
	}

}

2)dao

package com.bjc.dao;

import java.util.UUID;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;

@Repository
public class UserDao {
	
	@Autowired
	private JdbcTemplate jdbc;
	
	public void save() {
		String sql = "INSERT INTO `user`(name,age) VALUES(?,?)";
		String username = UUID.randomUUID().toString().substring(0, 5);
		jdbc.update(sql, username,23);
	}
	
}

1.4 测试

public class TxTest {

	public static void main(String[] args) {
		ApplicationContext context = new AnnotationConfigApplicationContext(TxConfig.class);
		UserService bean = context.getBean(UserService.class);
		bean.save();
	}

}

运行结果:

查看数据库:

2 添加事务控制

2.1 配置事务管理器

在配置类中添加如下方法:

//注册事务管理器在容器中
@Bean
public PlatformTransactionManager transactionManager() throws Exception{
	return new DataSourceTransactionManager(dataSource());
}

2.2 开启事务管理注解扫描——@EnableTransactionManagement

在配置类上加上注解@EnableTransactionManagement

注意:

1)这个是必须要开启的,如果不开启事务不生效

2)开启事务管理注解扫描之前,还需要配置事务管理器,否则报错

2.3 在业务类上添加事务控制注解——@Transactional

注意:该注解也可以用于类上,表示该类上的所有方法都需要事务控制

基于径向基函数神经网络RBFNN的自适应滑模控制学习(Matlab代码实现)内容概要:本文介绍了基于径向基函数神经网络(RBFNN)的自适应滑模控制方法,并提供了相应的Matlab代码实现。该方法结合了RBF神经网络的非线性逼近能力和滑模控制的强鲁棒性,用于解决复杂系统的控制问题,尤其适用于存在不确定性和外部干扰的动态系统。文中详细阐述了控制算法的设计思路、RBFNN的结构与权重更新机制、滑模面的构建以及自适应律的推导过程,并通过Matlab仿真验证了所提方法的有效性和稳定性。此外,文档还列举了大量相关的科研方向和技术应用,涵盖智能优化算法、机器学习、电力系统、路径规划等多个领域,展示了该技术的广泛应用前景。; 适合人群:具备一定自动控制理论基础和Matlab编程能力的研究生、科研人员及工程技术人员,特别是从事智能控制、非线性系统控制及相关领域的研究人员; 使用场景及目标:①学习和掌握RBF神经网络与滑模控制相结合的自适应控制策略设计方法;②应用于电机控制、机器人轨迹跟踪、电力电子系统等存在模型不确定性或外界扰动的实际控制系统中,提升控制精度与鲁棒性; 阅读建议:建议读者结合提供的Matlab代码进行仿真实践,深入理解算法实现细节,同时可参考文中提及的相关技术方向拓展研究思路,注重理论分析与仿真验证相结合。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值