首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JPQL更新查询

JPQL更新查询
EN

Stack Overflow用户
提问于 2013-10-18 15:23:38
回答 3查看 30.4K关注 0票数 2

我有一个这样的实体:

代码语言:javascript
复制
@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不工作,它抛出:

代码语言:javascript
复制
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,有没有什么方法可以修改它使其正常工作?

EN

回答 3

Stack Overflow用户

发布于 2013-10-18 15:54:46

我能够重写我需要的查询:

代码语言:javascript
复制
UPDATE LocalizedText L SET L.content = :content WHERE EXISTS (SELECT T FROM QuestionGroupText T WHERE T.localizedText.id = L.id AND T.generatedId = :generatedId)
票数 2
EN

Stack Overflow用户

发布于 2013-10-18 15:31:27

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

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

票数 0
EN

Stack Overflow用户

发布于 2013-10-18 15:38:19

您的属性localizedText是Entity LocalizedText表的外键

您的查询试图将:content (不管是哪种类型)设置为一个外键列。这不起作用。您是否定义了表LocalizedText?

您可以执行的操作:

  1. 使用content localizedText
  2. Or

为属性更新表设置新ID

请注意:当你想要一个Id时,你必须在QuestionGroupText中设置@Id注释。

generatedId看起来是正确的地方

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19443888

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档