我已经配置并运行了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);
参数division和section正在实现,但表中没有变化。
P.S。我也在使用mysql数据库。
答案 0 :(得分:111)
我正在使用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"/>
这是漫长的旅程,但我终于开始工作了。我希望这会帮助某人,试图“付出代价”,因为许多其他人帮助我完成了他们精彩的博客,答案和评论。
答案 1 :(得分:9)
要执行修改查询,您需要使用reference documentation中所述的其他@Modifying
注释该方法,如下所示:
@Modifying
@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);
答案 2 :(得分:8)
对我来说,它也适用于以下注释:
@Modifying
@Query("update User u set u.active=1 where a.id=?1")
@Transactional
void activeUser(Long id);
答案 3 :(得分:4)
对我而言,它适用于以下注释:
@Modifying
@Query("update JsonContactImport x set x.isImported = true where x.id in :ids")
@Transactional
void updateImported(@Param("ids") List<Long> ids);
答案 4 :(得分:0)
使用Spring 5,仍需要@Transactional注释。
@Repository
public interface DoorStyleRepository extends JpaRepository<DoorStyle, Long> {
@Modifying
@Transactional
@Query("UPDATE DoorStyle ds SET ds.enabled = false")
void setEnabledFalse();
}