我已配置并运行spring-data和hibernate。我可以使用spring- data保存记录,但是由于某些原因,我无法运行查询来更新表中的所有布尔字段。
我尝试了这个:
@Query("update Content v set v.published = false where v.division = :division and v.section = :section") void unPublishContent(@Param("division") String division, @Param("section") String section);
我也试过这个:
@Query("update Content v set v.published = 0 where v.division = :division and v.section = :section") void unPublishContent(@Param("division") String division, @Param("section") String section);
参数除法和节将实现,但表上未更改。
PS我也正在使用MySQL数据库。
我正在使用Spring 3.1和Spring JPA数据。我有一个类似的问题。尝试在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 ...
因此,我认为我的问题现在是交易问题,我回到Google进行研究,发现您必须立即添加@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"/>
这是一段漫长的旅程,但我终于使它工作了。我希望这将对某人有所帮助,并尝试“偿还”,因为许多其他人通过他们的博客,答案和评论为我提供了帮助。