繁体   English   中英

JPQL更新查询

[英]JPQL Update Query

我有一个这样的实体:

@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 ,我可以通过任何方式更改它来使其正常工作吗?

我能够重写所需的查询:

UPDATE LocalizedText L SET L.content = :content WHERE EXISTS (SELECT T FROM QuestionGroupText T WHERE T.localizedText.id = L.id AND T.generatedId = :generatedId)

您的属性localizedText是表的实体LocalizedText的外键

您的查询尝试将:content(无论是哪种类型)设置为外键列。 这是行不通的。 您是否定义了表格LocalizedText?

你可以做什么:

  1. 为您的属性localizedText设置一个新ID
  2. 或使用内容更新表LocalizedText

请注意:要获得ID时,必须在QuestionGroupText中设置@Id注释。

generateId接缝是正确的位置

在我看来,您正在尝试从此表中更新外键。

我认为正确的方法是更新LocalizedText。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM