EJB3实体映射之多表映射

EJB将一个类的属性映射到多张表中:

import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.PrimaryKeyJoinColumn;
import javax.persistence.SecondaryTable;


@Entity
// name 另一张表的表名 pkJoinColumns 另一张表的PK
@SecondaryTable(name = "Address",
pkJoinColumns = {@PrimaryKeyJoinColumn(name = "address_id")} )

public class MainTable implements Serializable{
private static final long serialVersionUID = 4016777473296175005L;
private Integer id;// 主键
private String name;// 姓名
private String address;// 地址,该映射的字段分布在Address表
private String postcode;// 邮编,该映射的字段分布在Address表

@Id
@GeneratedValue
public Integer getId() {
return id;
}

public void setId(Integer id) {
this.id = id;
}

@Column(nullable=false,length=32)
public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

// 指定映射到表名为 Address 的表中
@Column(table="Address")
public String getAddress() {
return address;
}

public void setAddress(String address) {
this.address = address;
}

// 指定映射到表名为 Address 的表中
@Column(length=6, table="Address")
public String getPostcode() {
return postcode;
}

public void setPostcode(String postcode) {
this.postcode = postcode;
}

@Override
public int hashCode() {
int hash = 0;
hash += (this.id != null ? this.id.hashCode() : 0);
return hash;
}

@Override
public boolean equals(Object object) {
if (!(object instanceof MainTable)) {
return false;
}
MainTable other = (MainTable)object;
if (this.id != other.id && (this.id == null || !this.id.equals(other.id))) return false;
return true;
}

@Override
public String toString() {
return this.getClass().getName()+ "[id="+id+ ",name="+ name+ ",address="+ address+ ",postcode="+ postcode + "]";
}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值