39

スプリングデータと休止状態を構成して実行しています。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

Spring3.1とSpringJPADataを使用しています。私も同様の問題を抱えていました。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 に答える