使用EclipseLink JPA2实现(不确定它是否与Hibernate实现相同)
我有一个简单的结构,其中组织实体有合同.这是我从postgres导出的sql以创建组织
CREATE TABLE organization (
key bigint NOT NULL,
version integer
);
如果我像这样指定本组织的合同方:
@ManyToOne( optional=false )
@JoinColumn( name="organization_key", referencedColumnName="key" )
private Organization organization;
然后转储我得到的模式.
CREATE TABLE contract (
key bigint NOT NULL,
version integer,
organization_key character varying(255),
);
对我来说,使用字符变化(255)字段来引用组织密钥是没有意义的.我知道我可以使用columnDefinition如下:
@ManyToOne( optional=false )
@JoinColumn( name="organization_key", referencedColumnName="key", columnDefinition="bigint NOT NULL" )
private Organization organization;
获取bigint类型而不是字符类型.
期望它获得正确的列类型对我来说是不现实的吗?我使用它错了,还是我有错误的期望?我每次都必须使用columnDefinition吗?
更新:
这是组织实体的相关信息
@Entity
@Table( name = "organization" )
@SequenceGenerator( name = "ORGANIZATION_SEQ_GEN", sequenceName = "ORGANIZATION_SEQUENCE" )
public class Organization
implements DataObject
{
/**
* key for this instance. Should be managed by JPA provider.
*/
@Id
@GeneratedValue( strategy = GenerationType.SEQUENCE, generator = "ORGANIZATION_SEQ_GEN" )
private Long key;
/**
* JPA version column
*/
@Version
protected int version;
/**
* All contracts for this organization
*/
@OneToMany(mappedBy="organization" )
@OrderBy( "endDate DESC" )
private List contracts;
... getters and setters
}
这是契约实体
@Entity
@Table( name = "contract" )
@SequenceGenerator( name = "CONTRACT_SEQ_GEN", sequenceName = "CONTRACT_SEQUENCE" )
public class Contract
implements DataObject
{
/**
* key for this instance. Should be managed by JPA provider.
*/
@Id
@GeneratedValue( strategy = GenerationType.SEQUENCE, generator = "CONTRACT_SEQ_GEN" )
private Long key;
/**
* Organization that owns this contract, required.
*/
@ManyToOne( optional=false )
@JoinColumn( name="organization_key", referencedColumnName="key" )
private Organization organization;
/**
* JPA version column
*/
@Version
protected int version;
... getters and setters
}