1:需要进行事物管理的业务
@Transactional
public class BasicDaoImpl implements BasicDao{
@Resource(name="sessionFactory",type=SessionFactory.class)
private SessionFactory sessionFactory;
private Session session;
public Session getSession()
{
return sessionFactory.getCurrentSession();
}
@Transactional
public boolean save(Object object)
{
session=this.getSession();
session.save(object);
System.out.println(9/0);
//发生错误事物进行回滚
return true;
}
}
2:Spring的配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
">
<!-- 开启注解处理器 -->
<context:annotation-config/>
<!-- 配置数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="jdbcUrl">
<value>jdbc:mysql://localhost:3306/management?useUnicode=true&characterEncoding=gbk</value>
</property>
<property name="user">
<value>userName</value>
</property>
<property name="password">
<value>userPassword</value>
</property>
<property name="maxPoolSize">
<value>10</value>
</property>
<property name="minPoolSize">
<value>1</value>
</property>
<property name="initialPoolSize">
<value>1</value>
</property>
<property name="maxIdleTime">
<value>30</value>
</property>
</bean>
<!-- 注册Hibernate -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="annotatedClasses">
<list>
<value>m.bean.User</value>
<value>m.bean.Account</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.current_session_context_class">thread</prop>
<prop key="hibernate.jdbc.batch_size">50</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
<prop key="hibernate.temp.use_jdbc_metadata_defaults">false</prop>
</props>
</property>
</bean>
<!-- 注册事物管理器 -->
<aop:aspectj-autoproxy/>
<bean id="txManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
<tx:annotation-driven transaction-manager="txManager"/>
<bean id="basicDaoImpl" class="m.dao.impl.BasicDaoImpl"/>
</beans>
3:测试用例
public class BasicDaoImplTest
{
private AbstractApplicationContext aac //Spring容器
private BasicDao basicDao; //基本数据操作接口
private User user; //用户
@Before
public void init()
{
aac=new ClassPathXmlApplicationContext("applicationContext.xml");
basicDao=(BasicDao)aac.getBean("basicDaoImpl");
}
@Test
public void save()
{
user=new User();
user.setAccount("dog4");
user.setPassword("dogjiayou");
user.setName("狗狗");
user.setAge(3);
user.setSex("男");
user.setGrade("用户");
user.setPhone("493204302941");
user.setBirthday(new Date());
user.setRegistDate(new Date());
boolean result=basicDao.save(user);
assertTrue(result);
}
}
4:Junit错误信息
org.hibernate.HibernateException: save is not valid without active transaction
说的意思好像是没有活动的事物,就无法使用session.getCurrentSession()方法,意思是
说我的注解实现事物管理没有成功,所双请教各位高手这个问题该如何解决?
380 阅读
session.getCurrentSession()?
你用这个?
引用来自“午后冬日”的答案
但Session还是得自己创建啊。
引用来自“aliuxu”的答案
那怎么把Hibernate的事物管理交给Spring容器?
难道要使用以前的编程式事物管理?
引用来自“玫瑰花的葬礼”的答案
引用来自“aliuxu”的答案
那怎么把Hibernate的事物管理交给Spring容器?
难道要使用以前的编程式事物管理?
容器启动的时候开个session , 这样就避免了currentsession()没有的尴尬