spring入门实例-DAO,声明事务

spring入门实例-DAO,事务

实例使用代理模式,使用DAO,并且添加事务功能

配置文件:

<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://www.springframework.org/schema/beans
	http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">

	<bean name="dataSource"
		class="org.springframework.jdbc.datasource.DriverManagerDataSource">

		<property name="driverClassName">
			<value>oracle.jdbc.driver.OracleDriver</value>
		</property>

		<property name="url">
			<value>jdbc:oracle:thin:@192.168.32.227:1521:orcl</value>
		</property>

		<property name="password">
			<value>lpromis</value>
		</property>

		<property name="username">
			<value>lpromis</value>
		</property>
	</bean>
	
	<bean id="transactionManager"
	class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource">
			<ref bean="dataSource"></ref>
		</property>
	</bean>
	
	<bean id="userDAO"
	class="com.myspring.bussiness.declare.DataSourceDAO">
		<property name="dataSource">
			<ref bean="dataSource"></ref>
		</property>
	</bean>
	
	<bean id="userDAOProxy"
	class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
		<property name="transactionManager">
			<ref bean="transactionManager"/>
		</property>
		<property name="target">
			<ref bean="userDAO"/>
		</property>
		<property name="transactionAttributes">
			<props>
				<prop key="insert*">PROPAGATION_REQUIRED</prop>
			</props>
		</property>
	</bean>

</beans>

使用 org.springframework.transaction.interceptor.TransactionProxyFactoryBean实现代理事务,事务处理类

transactionManager,DAO的bean是userDAO,代理事务属性设置为insert操作,

其中PROPAGATION_REQUIRED,是事务操作属性,还有许多,有兴趣可以自己看看api。

 

bean的实现:

/**
 * use declarative transaction
 * @author logichina
 * 
 */
public class DataSourceDAO
{
	private DataSource dataSource;

	public void setDataSource(DataSource dataSource)
	{
		this.dataSource = dataSource;
		this.jdbcTemplate = new JdbcTemplate(dataSource);
	}

	private JdbcTemplate jdbcTemplate;

	public void insertCustomer()
	{
		jdbcTemplate.update("insert into t_lpromis_yxgl_khxx(id,khqc) values('000023','testname4')");
		jdbcTemplate.update("insert into t_lpromis_yxgl_khxx(id,khqc) values('000024','testname5')");
		jdbcTemplate.update("insert into t_lpromis_yxgl_khxx(id,khqc) values('000023','testname6')");
	}
	
	public static void main(String[] args)
	{
		ApplicationContext context = new ClassPathXmlApplicationContext("com/myspring/bussiness/declare/datasourceDAO.xml");
		DataSourceDAO bean = (DataSourceDAO) context.getBean("userDAOProxy");
		bean.insertCustomer();
		
	}

}
 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Error creating bean with name 'dataSource' defined in class path resource [spring/spring-dao.xml]是一个Spring框架的错误。它表明在实例化bean之前,某个bean的后置处理器失败了,导致无法创建名为'dataSource'的bean。具体的错误信息是org.springframework.beans.factory.BeanCreationException: Cannot resolve reference to bean 'pt1' while setting bean property 'pointcut'。这个错误是由于在设置属性'pointcut'时,无法解析对bean 'pt1'的引用所致。进一步的错误信息是java.lang.IllegalStateException: Failed to introspect Class [org.springframework.aop.aspectj.AspectJExpressionPointcut] from ClassLoader [sun.misc.Launcher$AppClassLoader@18b4aac2]。这个错误是由于无法从ClassLoader [sun.misc.Launcher$AppClassLoader@18b4aac2]中内省Class [org.springframework.aop.aspectj.AspectJExpressionPointcut]所致。 根据提供的信息,可能的解决办法是: - 检查spring-dao.xml文件中的dataSource bean的定义是否正确,确保相关的依赖项被正确引入。 - 检查是否存在名为'pt1'的bean的定义,并确保它已正确配置和初始化。 - 检查相关的类是否正确地加载到ClassLoader中,可以尝试重新编译和构建项目,确保相关的类文件和依赖项正确地放置在项目结构中。 如果问题仍然存在,可能需要进一步分析和调试来确定具体的原因和解决方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Error creating bean with name 'dataSource' defined in class path resource [spring/spring-dao.xml]:](https://blog.csdn.net/qq_16836791/article/details/105197000)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [error creating bean with name sqlSessionFactory defined in class path resource spring/spring-mvc](https://blog.csdn.net/developerFBI/article/details/106631130)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值