有2个Dao
UserDaoImpl:
public void saveUser(User user) {
this.getHibernateTemplate().save(user);
}
AcclDaoImpl:
public void saveAccl(Accl accl) {
this.getHibernateTemplate().save(accl);
}
Service层
UserServiceImpl:
private IUserDao userDao;
private IAcclDao acclDao;
public void saveUser(User user, Accl accl) {
this.userDao.saveUser(user);
this.acclDao.saveAccl(accl);
}
applicationContext.xml:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation">
<value>classpath:hibernate.cfg.xml</value>
</property>
</bean>
<!--定义事务管理器-->
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref bean="sessionFactory"/>
</property>
</bean>
<tx:advice id="smAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="save*" propagation="REQUIRED"/>
<tx:method name="del*" propagation="REQUIRED"/>
<tx:method name="update*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut id="smMethod" expression="execution(* mm.s2sh.service.*.*(..))"/>
<aop:advisor pointcut-ref="smMethod" advice-ref="smAdvice"/>
</aop:config> <bean id="userAction" class="mm.s2sh.action.user.UserAction">
<property name="userService" ref="userService"></property>
</bean>
<bean id="userService" class="mm.s2sh.service.user.impl.UserServiceImpl">
<property name="userDao" ref="userDao"></property>
<property name="acclDao" ref="acclDao"></property>
</bean>
<bean id="userDao" class="mm.s2sh.dao.user.impl.UserDaoImpl">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<bean id="acclDao" class="mm.s2sh.dao.user.impl.AcclDaoImpl">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>提交的时候发现数据没有进入数据库
于是在Dao中save完后this.getSession().beginTransaction().commit();
Accl表中有个字段是unique的,我故意提交了一个已有数据,结果导致User表中插入一条数据,也就是说没有回滚
我感觉不应该用this.getSession().beginTransaction().commit();但是不用的话事务又没有提交进不了数据库
请问这个应该怎么弄才能做到正确回滚,第一次配S2SH,见笑了
UserDaoImpl:
public void saveUser(User user) {
this.getHibernateTemplate().save(user);
}
AcclDaoImpl:
public void saveAccl(Accl accl) {
this.getHibernateTemplate().save(accl);
}
Service层
UserServiceImpl:
private IUserDao userDao;
private IAcclDao acclDao;
public void saveUser(User user, Accl accl) {
this.userDao.saveUser(user);
this.acclDao.saveAccl(accl);
}
applicationContext.xml:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation">
<value>classpath:hibernate.cfg.xml</value>
</property>
</bean>
<!--定义事务管理器-->
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref bean="sessionFactory"/>
</property>
</bean>
<tx:advice id="smAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="save*" propagation="REQUIRED"/>
<tx:method name="del*" propagation="REQUIRED"/>
<tx:method name="update*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut id="smMethod" expression="execution(* mm.s2sh.service.*.*(..))"/>
<aop:advisor pointcut-ref="smMethod" advice-ref="smAdvice"/>
</aop:config> <bean id="userAction" class="mm.s2sh.action.user.UserAction">
<property name="userService" ref="userService"></property>
</bean>
<bean id="userService" class="mm.s2sh.service.user.impl.UserServiceImpl">
<property name="userDao" ref="userDao"></property>
<property name="acclDao" ref="acclDao"></property>
</bean>
<bean id="userDao" class="mm.s2sh.dao.user.impl.UserDaoImpl">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<bean id="acclDao" class="mm.s2sh.dao.user.impl.AcclDaoImpl">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>提交的时候发现数据没有进入数据库
于是在Dao中save完后this.getSession().beginTransaction().commit();
Accl表中有个字段是unique的,我故意提交了一个已有数据,结果导致User表中插入一条数据,也就是说没有回滚
我感觉不应该用this.getSession().beginTransaction().commit();但是不用的话事务又没有提交进不了数据库
请问这个应该怎么弄才能做到正确回滚,第一次配S2SH,见笑了
解决方案 »
- james服务器无法收到邮件的问题,请教各位大神
- 求个JNI方式获取硬盘序列号的包,兼容win8的,拜谢了~~~
- 求教一个问题,对MAP和LIST使用熟练的帮帮我吧,实在是头疼了
- jsp在win2003可以连接上,但是win2000就不行了
- 问个基础问题,请指教
- 发送邮件
- 网站访问一段时间就出现 "找不到服务器 "-无法显示网页 的问题
- 送分啦!!!!!!来者有分!!!!!!在线等待!
- Db_sql是个什么东东?
- 救命啊,关于java,tomcat配置问题。
- Spring中多线程注入SqlService注不进去,显示sqlService为null异常
- Struts2能进入Action但是找不到result的问题
@Transactional(readOnly = false)
有2个Dao
UserDaoImpl:
@Transactional(readOnly = false)
public void saveUser(User user) {
this.getHibernateTemplate().save(user);
}
AcclDaoImpl:
@Transactional(readOnly = false)
public void saveAccl(Accl accl) {
this.getHibernateTemplate().save(accl);
}
好像是这样 我也不是很清楚
或者在Dao中this.getSession().beginTransaction().commit();才能提交数据么?
但是用这两种方式又不能回滚....
expression="execution(* mm.s2sh.service.*.*(..))"我的UserServiceImpl在
package mm.s2sh.service.user.impl;
public class UserServiceImpl extends BaseService implements IUserService而IUserService在
package mm.s2sh.service.user;所以改成expression="execution(* mm.s2sh.service.user.*.*(..))"就好了
不需要配置<property name="hibernate.connection.autocommit">true</property>或者写this.getSession().beginTransaction().commit();不然就破坏spring的事务了