使用hibernate注解自动建表

有三张表(表A、表B、表C),分别包含id和name两个字段,其中id为主键;表ABC包含字段a_id,b_id,c_id,其中a_id参照表A的id,b_id参照表B的... 有三张表(表A、表B、表C),分别包含id和name两个字段,其中id为主键;表ABC包含字段a_id,b_id,c_id,其中a_id参照表A的id,b_id参照表B的id,c_id参照表C的id。这样的表格结构用Hibernate注解应该怎么标注啊?两张表的@ManyToMany我会,但是三张表的就做不出来了 展开
 我来答
别抢我远古妖王
2015-07-28 · 超过19用户采纳过TA的回答
知道答主
回答量:35
采纳率:0%
帮助的人:15万
展开全部
@Entity
@Table(name="a")
public class A {
@Id
private String id;
private String name;
@ManyToMany(targetEntity=C.class,cascade={CascadeType.ALL},mappedBy="a")
private List<C> c=new ArrayList<C>();
@ManyToMany(targetEntity=B.class,cascade={CascadeType.ALL})
@JoinTable(name="a_b",joinColumns=@JoinColumn(name="a_id"),inverseJoinColumns=@JoinColumn(name="b_id"))
private List<B> b=new ArrayList<B>();
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List<C> getC() {
return c;
}
public void setC(List<C> c) {
this.c = c;
}
public List<B> getB() {
return b;
}
public void setB(List<B> b) {
this.b = b;
}
}


@Entity
@Table(name="b")
public class B {
@Id
private String id;
private String name;
@ManyToMany(targetEntity=A.class,cascade={CascadeType.ALL},mappedBy="b")
private List<A> a=new ArrayList<A>();
@ManyToMany(targetEntity=C.class,cascade={CascadeType.ALL})
@JoinTable(name="b_c",joinColumns=@JoinColumn(name="b_id"),inverseJoinColumns=@JoinColumn(name="c_id"))
private List<C> c=new ArrayList<C>();
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List<A> getA() {
return a;
}
public void setA(List<A> a) {
this.a = a;
}
public List<C> getC() {
return c;
}
public void setC(List<C> c) {
this.c = c;
}
}


@Entity
@Table(name="c")
public class C {
@Id
private String id;
private String name;
@ManyToMany(targetEntity=A.class,cascade={CascadeType.ALL})
@JoinTable(name="c_a",joinColumns=@JoinColumn(name="c_id"),inverseJoinColumns=@JoinColumn(name="a_id"))
private List<A> a=new ArrayList<A>();
@ManyToMany(targetEntity=B.class,cascade={CascadeType.ALL},mappedBy="c")
private List<B> b=new ArrayList<B>();
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List<A> getA() {
return a;
}
public void setA(List<A> a) {
this.a = a;
}
public List<B> getB() {
return b;
}
public void setB(List<B> b) {
this.b = b;
}
}
追问
您这个程序,最后生成的是a_b、b_c,c_a这三张表,跟我的需求不一致。我想要生成表a_b_c,这张表包含三个字段a_id,b_id,c_id,分别参照表A的id、表B的id、表C的id,并且a_id,b_id,c_id为联合主键。期待您的再次帮助!
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式