使用@Query和休眠更新spring数据jpa中的布尔值
Posted
技术标签:
【中文标题】使用@Query和休眠更新spring数据jpa中的布尔值【英文标题】:updating boolean value in spring data jpa using @Query, with hibernate 【发布时间】:2012-04-30 12:09:04 【问题描述】:我已经配置并运行了 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);
参数划分和部分正在实现,但表上没有变化。
附言我也在用mysql数据库。
【问题讨论】:
【参考方案1】:要执行修改查询,您需要使用附加的 @Modifying
注释方法,如 reference documentation 中所述,如下所示:
@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);
【讨论】:
那么……这对你有用吗?我有点困惑你在说什么;) 抱歉 Oliver,有点累了,我打错了。不,它没有帮助。据我了解,如果您的存储库使用只读注释,则此选项“@Modifying”很有用。通过这种方式,您可以拥有主要是只读的 I 存储库,但它仍然允许您在其中包含写入方法。 这与readOnly
无关——至少没有直接关系。 readOnly
是关于交易的,@Modifying
是关于对EntityManager
的调用。当然,尝试在只读事务中执行修改方法是没有意义的。【参考方案2】:
我正在使用 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
...
所以,我认为我的问题现在是事务问题,然后我回到 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"/>
这是漫长的旅程,但我终于让它工作了。我希望这会帮助一些人,就像许多其他人通过他们精彩的博客、答案和 cmets 帮助我一样,尝试“向前支付”。
【讨论】:
应该不是必需的,因为 Spring Data 会自动将基于注释的事务应用于存储库接口。 还要确保注解是从 org.springframework.transaction.annotation 而不是 javax 导入的 完美答案!!非常感谢!【参考方案3】:对我来说,它使用以下注释:
@Modifying
@Query("update JsonContactImport x set x.isImported = true where x.id in :ids")
@Transactional
void updateImported(@Param("ids") List<Long> ids);
【讨论】:
【参考方案4】:对我来说,它也适用于以下注释:
@Modifying
@Query("update User u set u.active=1 where a.id=?1")
@Transactional
void activeUser(Long id);
【讨论】:
【参考方案5】:使用 Spring 5,@Transactional 注释仍然是必需的。
@Repository
public interface DoorStyleRepository extends JpaRepository<DoorStyle, Long>
@Modifying
@Transactional
@Query("UPDATE DoorStyle ds SET ds.enabled = false")
void setEnabledFalse();
【讨论】:
以上是关于使用@Query和休眠更新spring数据jpa中的布尔值的主要内容,如果未能解决你的问题,请参考以下文章
Spring Boot JPA:@Modifying @Query 没有效果
意外的令牌:在休眠状态下使用 spring data jpa 时的位置