EJB3中的多对多关系

下午弄了很久,看了别人的教程。配置出来要么就是数据库不符合多对多的关系,要么就是根本不符合逻辑。

 

后来找到别人的教程的例子,虽然表建立正确了,但是关系只能有一方控制,这可麻烦的很呢。比如:

 

以前在Hibernate中 知道 默认不配置invser的话 就是双方维护关系,比如 在 一个多对多的关系中A和B

,如果双方都维护关系的话,那么不管删除A还是删除B ,都可以同时删除它们之间对应的关系。


但是在EJB3中,却不能这样做,mappedBy配置在A段的话,那么就是B来维护关系了。那么如果A和B之间存在5个个关联的关系 ,当删除A的时候A和B的关系就还存在,这些关系是垃圾数据,A都不存在了还要A和B的关系干嘛?。这样是不是EJB3中的一个BUG???

或者高手给出一个好点的方案 最近爱上了EJB3 ,同时拥有的回调方法和方法拦截尤其让我更是欢喜,不会因为这些让我不爽吧。

 

现在这样类配置: 直接贴代码了。2个类

 

  1. /**
  2.  * 
  3.  */
  4. package com.tsts.oa.bean;
  5. import java.io.Serializable;
  6. import java.util.ArrayList;
  7. import java.util.Date;
  8. import java.util.List;
  9. import javax.persistence.CascadeType;
  10. import javax.persistence.Column;
  11. import javax.persistence.Entity;
  12. import javax.persistence.FetchType;
  13. import javax.persistence.GeneratedValue;
  14. import javax.persistence.GenerationType;
  15. import javax.persistence.Id;
  16. import javax.persistence.JoinColumn;
  17. import javax.persistence.JoinTable;
  18. import javax.persistence.ManyToMany;
  19. import javax.persistence.Table;
  20. /**
  21.  * @author sunyanan
  22.  * 
  23.  */
  24. @Table
  25. @Entity
  26. @SuppressWarnings("serial")
  27. public class Role implements Serializable {
  28.     private Long id; // 对象ID
  29.     private Date createDate; // 对象创建日期
  30.     private Date modifyDate; // 对象修改日期
  31.     private String roleName; // 角色名称
  32.     
  33.     private List<Staff> roleStaff = new ArrayList<Staff>(); // 该角色下包含的员工
  34.     @Id @GeneratedValue(strategy=GenerationType.SEQUENCE)
  35.     public Long getId() {
  36.         return id;
  37.     }
  38.     public void setId(Long id) {
  39.         this.id = id;
  40.     }
  41.     public Date getCreateDate() {
  42.         return createDate;
  43.     }
  44.     public void setCreateDate(Date createDate) {
  45.         this.createDate = createDate;
  46.     }
  47.     public Date getModifyDate() {
  48.         return modifyDate;
  49.     }
  50.     public void setModifyDate(Date modifyDate) {
  51.         this.modifyDate = modifyDate;
  52.     }
  53.     @Column(length=250)
  54.     public String getRoleName() {
  55.         return roleName;
  56.     }
  57.     public void setRoleName(String roleName) {
  58.         this.roleName = roleName;
  59.     }
  60.     @ManyToMany(cascade=CascadeType.REMOVE, fetch=FetchType.EAGER)
  61.     @JoinTable(name="rea_staff_role"
  62.             joinColumns={@JoinColumn(name="role_id")},
  63.             inverseJoinColumns={@JoinColumn(name="staff_id")}
  64.         )
  65.     public List<Staff> getRoleStaff() {
  66.         return roleStaff;
  67.     }
  68.     public void setRoleStaff(List<Staff> roleStaff) {
  69.         this.roleStaff = roleStaff;
  70.     }
  71. }
  1. /**
  2.  * 
  3.  */
  4. package com.tsts.oa.bean;
  5. import java.io.Serializable;
  6. import java.util.ArrayList;
  7. import java.util.Date;
  8. import java.util.List;
  9. import javax.persistence.CascadeType;
  10. import javax.persistence.Column;
  11. import javax.persistence.Entity;
  12. import javax.persistence.FetchType;
  13. import javax.persistence.GeneratedValue;
  14. import javax.persistence.GenerationType;
  15. import javax.persistence.Id;
  16. import javax.persistence.JoinColumn;
  17. import javax.persistence.JoinTable;
  18. import javax.persistence.ManyToMany;
  19. import javax.persistence.Table;
  20. /**
  21.  * @author sunyanan
  22.  * 
  23.  * 员工实体类
  24.  * 
  25.  */
  26. @Table
  27. @Entity
  28. @SuppressWarnings("serial")
  29. public class Staff implements Serializable {
  30.     private Long id; // 记录id
  31.     private Date createDate; // 对象创建日期
  32.     private Date modifyDate; // 对象修改日期
  33.     private String loginId; // 登录id
  34.     private String name; // 真实名字
  35.     private String password; // 密码
  36.     private String email; // 邮箱
  37.     private char sex; // 性别
  38.     
  39.     private List<Role> staffRole = new ArrayList<Role>(); // 该员工所拥有的角色组
  40.     @Id @GeneratedValue(strategy=GenerationType.SEQUENCE)
  41.     public Long getId() {
  42.         return id;
  43.     }
  44.     public void setId(Long id) {
  45.         this.id = id;
  46.     }
  47.     @Column(length=50)
  48.     public String getLoginId() {
  49.         return loginId;
  50.     }
  51.     public void setLoginId(String loginId) {
  52.         this.loginId = loginId;
  53.     }
  54.     @Column(length=50)
  55.     public String getName() {
  56.         return name;
  57.     }
  58.     public void setName(String name) {
  59.         this.name = name;
  60.     }
  61.     @Column(length=50)
  62.     public String getPassword() {
  63.         return password;
  64.     }
  65.     public void setPassword(String password) {
  66.         this.password = password;
  67.     }
  68.     @Column(length=50)
  69.     public String getEmail() {
  70.         return email;
  71.     }
  72.     public void setEmail(String email) {
  73.         this.email = email;
  74.     }
  75.     @Column(length=2)
  76.     public char getSex() {
  77.         return sex;
  78.     }
  79.     public void setSex(char sex) {
  80.         this.sex = sex;
  81.     }
  82.     public Date getCreateDate() {
  83.         return createDate;
  84.     }
  85.     public void setCreateDate(Date createDate) {
  86.         this.createDate = createDate;
  87.     }
  88.     public Date getModifyDate() {
  89.         return modifyDate;
  90.     }
  91.     public void setModifyDate(Date modifyDate) {
  92.         this.modifyDate = modifyDate;
  93.     }
  94.     @ManyToMany(cascade=CascadeType.REMOVE, fetch=FetchType.EAGER)
  95.     @JoinTable(name="rea_staff_role"
  96.             joinColumns={@JoinColumn(name="staff_id")},
  97.             inverseJoinColumns={@JoinColumn(name="role_id")}
  98.         )
  99.     public List<Role> getStaffRole() {
  100.         return staffRole;
  101.     }
  102.     public void setStaffRole(List<Role> staffRole) {
  103.         this.staffRole = staffRole;
  104.     }
  105.     
  106. }

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值