0

こんにちは、みんな

通常、CREATED_BY、LAST_UPDATED_BY、CREATION_DATE、LAST_UPDATED_DATEという名前のすべてのテーブルに4つのフィールドを配置するので、これを単一のクラスBaseDoに入れて、 EmployeeDoのようなクラスに継承するのはなぜかと思いました。問題は、このBaseDoに@Entityアノテーションを付ける場合、不要な@Idフィールドを1つ配置する必要があることです。これを達成する方法はありますか?

@Entity
@Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
public class BaseDo implements Serializable {
    private static final long serialVersionUID = 6685603264139140757L;
    @Column(name="CREATED_BY" , nullable =false )
    private String createdBy;
    @Column(name="LAST_UPDATED_BY", nullable =false )
    private String lastUpdatedBy;
    @Column(name="CREATION_DATE", nullable =false )
    private Date creationDate;
    @Column(name="LAST_UPDATED_DATE", nullable =false )
    private Date lastUpdationDate;
}

@Entity
@Table(name="EMPLOYEE")
public class EmployeeDo extends BaseDo implements Serializable {

    private static final long serialVersionUID = 4465521188079217243L;
    @Id
    @Column(name="EMPLOYEE_ID" )
    private String employeeId ;
}

どうもありがとう

4

1 に答える 1

1

@MappedSuperclassを使用する必要があります

これをチェックしてください

http://docs.oracle.com/javaee/5/api/javax/persistence/MappedSuperclass.html

于 2012-11-27T05:24:59.763 に答える