使用@Query,使用hibernate更新spring数据jpa中的boolean值

aki*_*aki 38 hibernate spring-data spring-data-jpa

我有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);
Run Code Online (Sandbox Code Playgroud)

我也试过这个:

 @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);
Run Code Online (Sandbox Code Playgroud)

参数division和section正在实现,但表中没有变化.

ps我也在使用mysql数据库.

Tch*_*uan 114

我正在使用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);
Run Code Online (Sandbox Code Playgroud)

错误:

org.hibernate.hql.QueryExecutionRequestException: Not supported for DML operations
Run Code Online (Sandbox Code Playgroud)

所以,谷歌搜索了一段时间后,我发现你必须添加@Modifying.

@Modifying  
@Query("UPDATE User u SET u.state = ?1 WHERE u.server.id = ?2")
public void updateAllUsers(long state, long serverid);
Run Code Online (Sandbox Code Playgroud)

但后来我收到以下错误:

...    
nested exception is org.springframework.dao.InvalidDataAccessApiUsageException: Executing an update/delete query; 
nested exception is javax.persistence.TransactionRequiredException: Executing an update/delete query
...
Run Code Online (Sandbox Code Playgroud)

所以,我认为我的问题现在是一个交易问题,我回去谷歌研究它,发现你现在必须添加@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);
Run Code Online (Sandbox Code Playgroud)

但后来我收到以下错误:

No value for key [org.apache.commons.dbcp.BasicDataSource (...) ] bound to thread
Run Code Online (Sandbox Code Playgroud)

我再次搜索了一段时间,得出的结论是我的配置错误,结果证明是真的.我错过了一些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"/>
Run Code Online (Sandbox Code Playgroud)

这是漫长的旅程,但我终于得到了它的工作.我希望这会帮助某些人,试图"付出代价",因为许多其他人帮助我完成他们精彩的博客,答案和评论.

  • 不应该使用<tx:annotation-driven />,因为Spring Data会自动将基于注释的事务应用于存储库接口. (2认同)

Oli*_*ohm 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);
Run Code Online (Sandbox Code Playgroud)


小智 8

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

@Modifying
@Query("update User u set u.active=1 where a.id=?1")
@Transactional
void  activeUser(Long id);
Run Code Online (Sandbox Code Playgroud)