【问题标题】:JPQL Update QueryJPQL 更新查询
【发布时间】:2013-10-18 07:23:38
【问题描述】:

我有一个这样的实体:

@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,有什么办法可以更改它以使其正常工作吗?

【问题讨论】:

    标签: java sql hibernate jpa jpql


    【解决方案1】:

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

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

    【讨论】:

      【解决方案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)
      

      【讨论】:

        【解决方案3】:

        您的属性本地化文本是实体 LocalizedText 表的外键

        您的查询尝试将 :content (无论这可能是什么类型)设置为外键列。这不起作用。你有定义表 LocalizedText 吗?

        你可以做什么:

        1. 为您的属性本地化文本设置一个新 ID
        2. 或者用内容更新 Table LocalizedText

        请注意:当您需要 Id 时,您必须在 QuestionGroupText 中设置 @Id 注释。

        generatedId 接缝是正确的地方

        【讨论】:

          猜你喜欢
          • 2019-07-16
          • 2020-07-03
          • 2020-05-03
          • 2019-03-01
          • 2014-06-17
          • 2013-03-23
          • 2021-08-10
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多