hibernate交spring事务托管后插入数据无效,不发送sql语句,不报错,但能查询到数据。
如果手动执行sessionFactory.getCurrentSession().flush()可以立即写入到数据库。
不手动的话无法自动事务提交。
怀疑是spring事务管理没起作用。
(学生党刚学框架,不妥当的地方还请明示)
dao层代码:
public class UserDao implements IUserDao{
private SessionFactory sessionFactory;
public SessionFactory getSessionFactory() {
return sessionFactory;
}
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
public boolean addUser(User user) {
LogUtil.getLog().info("正在执行user插入操作~");
try {
sessionFactory.getCurrentSession().save(user);
} catch (Exception e) {
LogUtil.getLog().error(e);
return false;
}
return true;
}
controller层:
if(code.equals(checkCode)){
if(userDao.addUser(user)){
//将用户信息加进session中
return "redirect:/returnIndex";
}else{
model.addAttribute("message", "系统异常,注册失败!");
return "forward:/user/returnRegiste";
}
}else{
model.addAttribute("message", "验证码错误!");
return "forward:/user/returnRegiste";
}
xml配置:
<!-- c3p0数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close">
<property name="user"><value>root</value></property>
<property name="password"><value></value></property>
<property name="minPoolSize"><value>20</value></property>
<property name="maxPoolSize"><value>100</value></property>
<property name="initialPoolSize"><value>20</value></property>
<property name="driverClass"><value>com.mysql.jdbc.Driver</value></property>
<property name="jdbcUrl"><value>jdbc:mysql://localhost:3306/db_shop?useUnicode=true&characterEncoding=UTF-8</value></property>
</bean>
<!-- session工厂 -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="annotatedClasses">
<list>
<value>edu.hnuc.entity.User</value>
</list>
</property>
<property name="dataSource" ref="dataSource"></property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.dialect">edu.hnuc.util.UTF8CharacterDialect</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>
<!-- 事务管理器 -->
<bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<!-- 通知 -->
<tx:advice id="myAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="get*" read-only="true"/>
<tx:method name="*" />
</tx:attributes>
</tx:advice>
<!-- 切入点 -->
<aop:config>
<aop:pointcut expression="execution(* edu.hnuc.dao.impl.*.*(**))" id="myPoincut"/>
<aop:advisor advice-ref="myAdvice" pointcut-ref="myPoincut"/>
</aop:config>
<!-- openSessionInView -->
<mvc:interceptors>
<bean class="org.springframework.orm.hibernate4.support.OpenSessionInViewInterceptor">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
</mvc:interceptors>
文件结构:
PHPz2017-04-18 09:47:13
你設定檔裡面都沒有設定事務,怎麼自動提交?一定只能你自己手動在程式碼裡面提交交易才行了
最簡單的就是這樣
<tx:annotation-driven transaction-manager="transactionManager" />
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
然後在你dao方法上面加@Transactional
更新評論裡面的回答
這樣寫
<aop:pointcut expression="execution(* edu.hnuc.dao.impl.*.*(..))" id="myPoincut"/>
ringa_lee2017-04-18 09:47:13
1、既然用了springMVC和hibernate,為啥不用spring的hibernateTemplate呢?
2、你的spring設定檔中配置sessinFactory和transactionManager,但你的DAO中卻自己從sessionFactory中取得session,而且沒有相關的事物控制碼…我認為就是因為這個導致事物沒有被提交。就好比你用了連接池,卻自己用JDBCDriver創建了一個connection,那連接池肯定管理不了這個Connection啊,因為它都不知道有這麼個連接…
最後給你一個建議:調試階段的程式碼,e.printStackTrace()還是加上的好,而且最好加上throw e,這樣讓上游程式碼知道本層出了問題,否則,很可能因為人為的因素(例如忘了寫「LogUtil.getLog().error(e);」或其他)導致異常訊息被吞掉,如果發生這樣吞異常的情況,定位問題將是十分繁瑣的。