我正在使用 Spring 3.1 和 Spring JPA Data。我遇到了类似的问题。尝试在 1 个查询中更新多条记录时,我经常遇到错误。
所以,我有这样的事情。
@Query("UPDATE User u SET u.state = ?1 WHERE u.server.id = ?2")
public void updateAllUsers(long state, long serverid);
错误:
org.hibernate.hql.QueryExecutionRequestException: Not supported for DML operations
所以,谷歌搜索了一段时间后,我发现你必须添加@Modifying。
@Modifying
@Query("UPDATE User u SET u.state = ?1 WHERE u.server.id = ?2")
public void updateAllUsers(long state, long serverid);
但后来我收到以下错误:
...
nested exception is org.springframework.dao.InvalidDataAccessApiUsageException: Executing an update/delete query;
nested exception is javax.persistence.TransactionRequiredException: Executing an update/delete query
...
所以,我认为我的问题现在是事务问题,我回到谷歌研究它,发现你现在必须添加@Transactional。看来@Modifying 也需要@Transactional。
@Modifying
@Transactional
@Query("UPDATE User u SET u.state = ?1 WHERE u.server.id = ?2")
public void updateAllUsers(long state, long serverid);
但后来我收到以下错误:
No value for key [org.apache.commons.dbcp.BasicDataSource (...) ] bound to thread
我再次用谷歌搜索了一段时间,得出的结论是我的配置是错误的,结果证明是真的。我错过了一些 xml 配置。
<beans:bean class="org.springframework.orm.jpa.JpaTransactionManager" id="transactionManager">
<beans:property name="entityManagerFactory" ref="entityManagerFactory"/>
</beans:bean>
<tx:annotation-driven transaction-manager="transactionManager"/>
这是一段漫长的旅程,但我终于让它工作了。我希望这会帮助一些人,因为许多其他人通过他们精彩的博客、答案和评论帮助我,试图“向前支付”。