【问题标题】:Updating a cross - reference table with jOOQ使用 jOOQ 更新交叉引用表
【发布时间】:2014-01-02 23:58:17
【问题描述】:

我有表 UsersFactors 和交叉引用 UserFactors

当我在交叉引用表上使用store() 方法时,在设置两个 id 之后:

UserFactorsPOJO userFactors = new UserFactorsPOJO();
userFactors.setUserId(userId);
userFactors.setFactorId(FactorId);
userFactors.setValue(value);
UserFactorsRecord userFactRec = create.newRecord(UserFactors.USER_FACTORS, userFactors);
userFactRec.store();

Jooq 尝试插入一条记录,显然是因为我将 ID 设置为 POJO 并存储它。我收到“Unique index or primary key violation”错误。

如何使用两个 id 检索我想要的行,然后更新该行?

【问题讨论】:

    标签: java sql jooq


    【解决方案1】:

    如果您真的要更新单个 ID 的单个值,则不应使用 jOOQ 的 UpdatableRecord 来完成任务以避免发出两个查询。最简单的解决方案是这样的:

    create.update(USER_FACTORS)
          .set(USER_FACTORS.VALUE, value)
          .where(USER_FACTORS.FACTOR_ID.eq(factorId))
          .execute();
    

    请参阅手册中有关the UPDATE statement 的部分。如果您打算进行更复杂的更新,您也可以尝试使用jOOQ's MERGE statement support,尽管在此示例中,我认为您不需要MERGE

    【讨论】:

    • 这是有道理的。我想在我的情况下,我应该在 where 子句中添加第二个条件,用于第二个外键:.where(USER_FACTORS.FACTOR_ID.eq(factorId).and(UserFactors.USER_FACTORS.USER_ID.eq(userId))
    【解决方案2】:

    这是我能想到的最好的了。欢迎提出其他建议。

        UserFactorsRecord userFactRec = create.fetchOne(UserFactors.USER_FACTORS, 
                UserFactors.USER_FACTORS.FACTOR_ID.eq(factorId).and(UserFactors.USER_FACTORS.USER_ID.eq(userId)));
        userFactRec.setValue(value);
        userFactRec.store();
    

    【讨论】:

      猜你喜欢
      • 2013-11-18
      • 1970-01-01
      • 1970-01-01
      • 2017-06-29
      • 2015-10-08
      • 1970-01-01
      • 2020-10-21
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多