39

我已经配置并运行了 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数据库。

4

5 回答 5

115

我正在使用 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"/>

这是一段漫长的旅程,但我终于让它工作了。我希望这会帮助一些人,因为许多其他人通过他们精彩的博客、答案和评论帮助我,试图“向前支付”。

于 2012-09-14T14:02:06.893 回答
10

要执行修改查询,您需要使用参考文档@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);
于 2012-04-19T07:44:39.197 回答
8

对我来说,它也适用于以下注释:

@Modifying
@Query("update User u set u.active=1 where a.id=?1")
@Transactional
void  activeUser(Long id);
于 2015-05-27T00:54:36.897 回答
4

对我来说,它使用以下注释:

@Modifying
@Query("update JsonContactImport x set x.isImported = true where x.id in :ids")
@Transactional
void updateImported(@Param("ids")  List<Long> ids);
于 2013-09-22T16:42:49.177 回答
0

使用 Spring 5,仍然需要 @Transactional 注释。

@Repository
public interface DoorStyleRepository extends JpaRepository<DoorStyle, Long> {

    @Modifying
    @Transactional
    @Query("UPDATE DoorStyle ds SET ds.enabled = false")
    void setEnabledFalse();
}
于 2019-04-10T20:28:43.723 回答