【问题标题】:JPA Hibernate map fields from class within class to same tableJPA Hibernate 将类中的类中的字段映射到同一个表
【发布时间】:2018-04-30 14:37:00
【问题描述】:

我有一个“审计”类,它将包含有关实体的以下详细信息:

  • 创建时间
  • 由哪个应用程序用户创建
  • 时间更新
  • 由哪个应用程序用户更新

在数据库中,这些字段与实体属性存储在同一个表中。例如,

USER 表:

CREATE TABLE USERS (
    id                  BIGINT          NOT NULL    AUTO_INCREMENT,
    display_name        VARCHAR(30)     NOT NULL,

    active              BOOLEAN         NOT NULL    DEFAULT FALSE,

    created_time        TIMESTAMP       NOT NULL    DEFAULT CURRENT_TIMESTAMP,
    created_user        BIGINT          NOT NULL    DEFAULT 0,
    updated_time        TIMESTAMP       NOT NULL    DEFAULT 0,
    updated_user        BIGINT          NOT NULL    DEFAULT 0,

    PRIMARY KEY (id)
);

用户类:

@Entity(name="USER")
@Table(name="USERS")
public class User implements Audited {

    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    @Column(name="ID", nullable=false, updatable=false)
    private long id;

    @Column(name="DISPLAY_NAME", nullable=false)
    @NotNull
    @Size(min=5, max=30)
    private String displayName;

    @Column(name="ACTIVE", nullable=false)
    @NotNull
    private boolean active;

    private Audit audit;
}

审计类:

public class Audit {

    private Date createdTime;

    private User createdByUser;

    private Date updatedTime;

    private User updatedByUser;
}

在每个实体表上,审计字段的名称都相同。映射这些字段的最佳方法是什么?

【问题讨论】:

    标签: java mysql hibernate jpa orm


    【解决方案1】:

    最好的方法是将Audit 类作为@Embeddable 实体并在您的所有实体中将其用作@Embedded 属性,这几乎是您目前正在做的事情。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-03-31
      • 2012-07-15
      • 2010-12-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-02-06
      • 1970-01-01
      相关资源
      最近更新 更多