2

次のようなエンティティがあります。

@Entity
@Table(name = "QUESTION_GROUP_TEXT")
@NamedQueries({
        @NamedQuery(
                name = EntityUtils.NamedQuery.UPDATE_QUESTION_GROUP_TEXT,
                query = "UPDATE QuestionGroupText T SET T.localizedText.content = :content WHERE T.generatedId = :generatedId")
})
public class QuestionGroupText implements Serializable {

    @Column(name = "GENERATED_ID", nullable = false, unique = true)
    private String generatedId = generateId();

    @ManyToOne(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
    @JoinColumn(name = "LOCALIZED_TEXT_ID", nullable = false)
    private LocalizedText localizedText;

    //Getters and setters

}

このクエリ:UPDATE QuestionGroupText T SET T.localizedText.content = :content WHERE T.generatedId = :generatedIdは機能しません。スローされます:

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'set CONTENT='Question Label' where GENERATED_ID='AD78F9B5E2A146D9AB9D94096DA835B' at line 1

クエリのこの部分に何か問題があるはずです: T.localizedText.content、これを機能させるために変更する方法はありますか?

4

3 に答える 3

2

必要なクエリを書き直すことができました。

UPDATE LocalizedText L SET L.content = :content WHERE EXISTS (SELECT T FROM QuestionGroupText T WHERE T.localizedText.id = L.id AND T.generatedId = :generatedId)
于 2013-10-18T07:54:46.417 に答える
0

属性 localizedText は、エンティティ LocalizedText のテーブルへの外部キーです

クエリは、:content (これがどのようなタイプであっても) を外部キー列に設定しようとします。これは動作しません。テーブル LocalizedText が定義されていますか?

できること:

  1. 新しい ID を属性 localizedText に設定します
  2. または、コンテンツで Table LocalizedText を更新します

注意: ID が必要な場合は、QuestionGroupText 内に @Id アノテーションを設定する必要があります。

generatedId シームを適切な場所に配置する

于 2013-10-18T07:38:18.727 に答える