代码执行到 Query q = getSession().createQuery(“hql”); 没有报错,但是不再往下执行了。
尝试try catch。
try {
getSession();
} catch (Exception e) {
e.printStackTrace();
}
控制台报错。
HibernateException: Could not obtain transaction-synchronized Session for current thread。
解决方法:在该方法上添加@Transactional注解之后,可以顺利执行。
百度还有另外的解决方法,在web.xml 中添加过滤器。
<filter>
<filter-name>openSessionInView</filter-name>
<filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>openSessionInView</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-name>openSessionInView</filter-name>
<filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>openSessionInView</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
不过这种方法并没有解决我的问题。
解决Hibernate事务同步问题
本文讨论了在使用Spring框架和Hibernate进行持久化操作时遇到的事务同步问题,具体表现为代码执行到特定位置后不再继续执行。通过添加@Transactional注解和在web.xml中配置OpenSessionInViewFilter,最终解决了Hibernate无法获得当前线程会话的问题。
4914

被折叠的 条评论
为什么被折叠?



