博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Spring 申明式事务之XML模式
阅读量:4049 次
发布时间:2019-05-25

本文共 3779 字,大约阅读时间需要 12 分钟。

– Start


package shangbo.spring.transaction.jdbc.schema;public class Job {	private String jobId;	private String jobTitle;	private Integer minSalary;	private Integer maxSalary;	public String getJobId() {		return jobId;	}	public void setJobId(String jobId) {		this.jobId = jobId;	}	public String getJobTitle() {		return jobTitle;	}	public void setJobTitle(String jobTitle) {		this.jobTitle = jobTitle;	}	public Integer getMinSalary() {		return minSalary;	}	public void setMinSalary(Integer minSalary) {		this.minSalary = minSalary;	}	public Integer getMaxSalary() {		return maxSalary;	}	public void setMaxSalary(Integer maxSalary) {		this.maxSalary = maxSalary;	}	public String toString() {		return "Job[jobId=" + jobId + ", jobTitle=" + jobTitle + ", minSalary=" + minSalary + ", maxSalary=" + maxSalary + "]";	}}
package shangbo.spring.transaction.jdbc.schema;import org.apache.commons.dbcp.BasicDataSource;public interface BusinessService {	Job getJob(String jobId);	void insertJob(Job job) throws Exception;	void updateJob(Job job) throws Exception;	void setDataSource(BasicDataSource dataSource);}
package shangbo.spring.transaction.jdbc.schema;import java.sql.ResultSet;import java.sql.SQLException;import org.apache.commons.dbcp.BasicDataSource;import org.springframework.jdbc.core.JdbcTemplate;import org.springframework.jdbc.core.RowMapper;public class DefaultBusinessService implements BusinessService {	private JdbcTemplate jdbcTemplate;	public Job getJob(String jobId) {		String sql = "SELECT * FROM HR.JOBS WHERE JOB_ID = ?";		return jdbcTemplate.queryForObject(sql, new JobRowMapper(), jobId);	}	public void updateJob(Job job) throws Exception {		String sql = "UPDATE HR.JOBS SET JOB_TITLE=?, MIN_SALARY = ?, MAX_SALARY = ? WHERE JOB_ID = ?";		jdbcTemplate.update(sql, job.getJobTitle(), job.getMinSalary(), job.getMaxSalary(), job.getJobId());		// 测试回滚		// throw new Exception("test");	}	public void insertJob(Job job) throws Exception {		String sql = "INSERT INTO HR.JOBS VALUES (?, ?, ?, ?)";		jdbcTemplate.update(sql, job.getJobId(), job.getJobTitle(), job.getMinSalary(), job.getMaxSalary());		// 测试回滚		// throw new Exception("test");	}	public void setDataSource(BasicDataSource dataSource) {		this.jdbcTemplate = new JdbcTemplate(dataSource);	}	private static class JobRowMapper implements RowMapper
{ public Job mapRow(ResultSet rs, int rowNum) throws SQLException { Job job = new Job(); job.setJobId(rs.getString(1)); job.setJobTitle(rs.getString(2)); job.setMinSalary(rs.getInt(3)); job.setMaxSalary(rs.getInt(4)); return job; } }}
package shangbo.spring.transaction.jdbc.schema;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;public class App {	public static void main(String[] args) throws Exception {		// 实例化 Spring IoC 容器		ApplicationContext context = new ClassPathXmlApplicationContext("example.xml", BusinessService.class);		// 从容器中获得 BusinessService 的实例		BusinessService service = context.getBean(BusinessService.class);		// 使用 BusinessService		// 插入 job		Job job = newJob();		// service.insertJob(job);		// 更新 job		service.updateJob(job);		// 查询 job		System.out.println(service.getJob("IT"));	}	private static Job newJob() {		Job job = new Job();		job.setJobId("IT");		job.setJobTitle("IT Engineer");		job.setMinSalary(3);		job.setMaxSalary(100000);		return job;	}}

– 声 明:转载请注明出处
– Last Updated on 2017-06-12
– Written by ShangBo on 2017-06-12
– End

你可能感兴趣的文章
Spring JTA应用之JOTM配置
查看>>
spring JdbcTemplate 的若干问题
查看>>
Servlet和JSP的线程安全问题
查看>>
GBK编码下jQuery Ajax中文乱码终极暴力解决方案
查看>>
Oracle 物化视图
查看>>
PHP那点小事--三元运算符
查看>>
解决国内NPM安装依赖速度慢问题
查看>>
Brackets安装及常用插件安装
查看>>
Centos 7(Linux)环境下安装PHP(编译添加)相应动态扩展模块so(以openssl.so为例)
查看>>
fastcgi_param 详解
查看>>
Nginx配置文件(nginx.conf)配置详解
查看>>
标记一下
查看>>
IP报文格式学习笔记
查看>>
autohotkey快捷键显示隐藏文件和文件扩展名
查看>>
Linux中的进程
查看>>
学习python(1)——环境与常识
查看>>
学习设计模式(3)——单例模式和类的成员函数中的静态变量的作用域
查看>>
自然计算时间复杂度杂谈
查看>>
当前主要目标和工作
查看>>
使用 Springboot 对 Kettle 进行调度开发
查看>>