栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用@Query和Hibernate更新spring数据jpa中的布尔值

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用@Query和Hibernate更新spring数据jpa中的布尔值

我正在使用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  id="transactionManager">    <beans:property name="entityManagerFactory" ref="entityManagerFactory"/></beans:bean><tx:annotation-driven transaction-manager="transactionManager"/>

这是一段漫长的旅程,但我终于使它工作了。我希望这将对某人有所帮助,并尝试“偿还”,因为许多其他人通过他们的博客,答案和评论为我提供了帮助。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/447528.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号