Spring之JdbcTemplate实现封装

首先配置config.xml

	<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
		<property name="driverClassName">
			<value>com.mysql.jdbc.Driver</value>
		</property>
		<property name="url">
			<value>jdbc:mysql://localhost:3306/mytest1</value>
		</property>
		<property name="username">
			<value>root</value>
		</property>
		<property name="password">
			<value>123</value>
		</property>
	</bean>
	
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource">
			<ref bean="dataSource"/>
		</property>
	</bean>
	<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
		<property name="dataSource">
			<ref bean = "dataSource"/>
		</property>
	</bean>
	<bean id="helloDao" class="com.gc.action.HelloDao">
	
		<property name="jdbcTemplate">
			<ref bean="jdbcTemplate"/>
		</property>
		<property name="transactionManager">
			<ref bean = "transactionManager"/>
		</property>
		<property name="sql">
			<value>insert into tb1 values(101,'gf','nihao')</value>
		</property>
		
	</bean>
	
再是实现的helloDao类

package com.gc.action;

import javax.sql.DataSource;

import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.TransactionStatus;
import org.springframework.transaction.support.DefaultTransactionDefinition;
import org.springframework.transaction.support.TransactionCallback;
import org.springframework.transaction.support.TransactionTemplate;

public class HelloDao {
	//private DataSource dataSource;
	private JdbcTemplate jdbcTemplate;
	private PlatformTransactionManager transactionManager;
	private String sql;
	
public void setSql(String sql) {
		this.sql = sql;
	}


	public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
		this.jdbcTemplate = jdbcTemplate;
	}

	public void setTransactionManager(PlatformTransactionManager transactionManager) {
		this.transactionManager = transactionManager;
	}


	public void create(String name){
		DefaultTransactionDefinition def = new DefaultTransactionDefinition();
		TransactionStatus status = transactionManager.getTransaction(def);
		try {

			jdbcTemplate.update(this.sql);
		} catch (DataAccessException ex) {
			transactionManager.rollback(status);
			throw ex;
		}finally{
			transactionManager.commit(status);
		}
		System.out.println("*************************");
	}
}
最后测试类:

package com.gc.test;



import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;

import com.gc.action.HelloDao;
import com.gc.impl.FinanceInterface;
import com.gc.impl.TimeBookInterface;


public class testExample {

	public static void main(String[] args) throws InstantiationException,IllegalAccessException,
	ClassNotFoundException{
		String path = "D:\\tianWorkPlace\\5_2\\WebContent\\config.xml";
		ApplicationContext actx = new FileSystemXmlApplicationContext(path);
//		FinanceInterface financeProxy = (FinanceInterface) actx.getBean("logProxy");
//		financeProxy.doCheck("李四");
		
		HelloDao hello = (HelloDao) actx.getBean("helloDao");
		//timeBookProxy.doCheck("zhang San");
		hello.create("zhang san");
	}

}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值