Eclipse JBoss EJB3实现Entity Bean的多对多映射
创始人
2024-04-06 04:21:20
0

在EJB3中需要使用@ManyToMany对封装多对多关系的字段或getter方法进行注释。先看看下面的表:

t_addresses表 图1  t_addresses表

t_addresses表和t_customers表是多对多的关系。需要使用一个关联表来描述这种关系,关联表的结构如下图所示。

t_customers_addresses 图2  t_customers_addresses

在Customer类中定义一个Collection < ADDRESS>类型的字段(addresses),用于保存与该Customer对象相对应的多个Address对象,代码如下:

  1. package entity;  
  2.  
  3. import java.util.Collection;  
  4.  
  5. import javax.persistence.CascadeType;  
  6. import javax.persistence.Entity;  
  7. import javax.persistence.FetchType;  
  8. import javax.persistence.GeneratedValue;  
  9. import javax.persistence.GenerationType;  
  10. import javax.persistence.Id;  
  11. import javax.persistence.JoinColumn;  
  12. import javax.persistence.JoinTable;  
  13. import javax.persistence.ManyToMany;  
  14. import javax.persistence.OneToMany;  
  15. import javax.persistence.OneToOne;  
  16. import javax.persistence.PrimaryKeyJoinColumn;  
  17. import javax.persistence.Table;  
  18.  
  19. @Entity 
  20. @Table(name = "t_customers")  
  21. public class Customer  
  22. {  
  23.     private int id;  
  24.     private String name;  
  25.     private Referee referee;  
  26.     private Collection< Order> orders;  
  27.  
  28.     private Collection< Address> addresses;  
  29.  
  30.     @ManyToMany(cascade = CascadeType.PERSIST, fetch = FetchType.LAZY)  
  31.     @JoinTable(name = "t_customers_addresses", joinColumns = @JoinColumn(name = "customer_id",   
  32.      referencedColumnName = "id"), inverseJoinColumns = @JoinColumn(name = "address_id", referencedColumnName = "id"))  
  33.     public Collection< Address> getAddresses()  
  34.     {  
  35.         return addresses;  
  36.     }  
  37.  
  38.     ... ...  
  39. }  
  40.  
  41.     @JoinTable注释用于指定连接表和t_customers及t_addresses表的连接字段关系。  
  42.     Address类的代码如下:  
  43. package entity;  
  44.  
  45. import java.util.Collection;  
  46.  
  47. import javax.persistence.CascadeType;  
  48. import javax.persistence.Entity;  
  49. import javax.persistence.FetchType;  
  50. import javax.persistence.GeneratedValue;  
  51. import javax.persistence.GenerationType;  
  52. import javax.persistence.Id;  
  53. import javax.persistence.ManyToMany;  
  54. import javax.persistence.Table;  
  55. @Entity 
  56. @Table(name="t_addresses")  
  57. public class Address  
  58. {  
  59.     private int id;  
  60.     private String addressLine;  
  61.     private String country;  
  62.     private String postCode;  
  63.     private Collection< Customer> customers;  
  64.     @Id 
  65.     @GeneratedValue(strategy=GenerationType.IDENTITY)  
  66.     public int getId()  
  67.     {  
  68.         return id;  
  69.     }  
  70.     public void setId(int id)  
  71.     {  
  72.         this.id = id;  
  73.     }  
  74.     public String getAddressLine()  
  75.     {  
  76.         return addressLine;  
  77.     }  
  78.     public void setAddressLine(String addressLine)  
  79.     {  
  80.         this.addressLine = addressLine;  
  81.     }  
  82.     public String getCountry()  
  83.     {  
  84.         return country;  
  85.     }  
  86.     public void setCountry(String country)  
  87.     {  
  88.         this.country = country;  
  89.     }  
  90.     public String getPostCode()  
  91.     {  
  92.         return postCode;  
  93.     }  
  94.     public void setPostCode(String postCode)  
  95.     {  
  96.         this.postCode = postCode;  
  97.     }  
  98.     @ManyToMany(mappedBy="addresses")  
  99.     public Collection< Customer> getCustomers()  
  100.     {  
  101.         return customers;  
  102.     }  
  103.     public void setCustomers(Collection< Customer> customers)  
  104.     {  
  105.         this.customers = customers;  
  106.     }      
  107. }  

由于是多对多的关系,因此,在Address类中需要定义一个Collection类型的字段(customers)用来保存与该Address对象相对应的Customer对象。getCustomers方法也需要使用@ManyToMany进行注释。可以使用下面代码进行测试:

  1. Customer customer = new Customer();  
  2. customer.setName("微软11");  
  3. List< Address> addresses = new ArrayList< Address>();  
  4. Address address = new entity.Address();  
  5. address.setAddressLine("address1");  
  6. address.setCountry("中国");   
  7. address.setPostCode("12345678");  
  8. addresses.add(address);  
  9. address = new entity.Address();  
  10. address.setAddressLine("address2");  
  11. address.setCountry("美国");   
  12. address.setPostCode("4321");  
  13. addresses.add(address);  
  14. customer.setAddresses(addresses);  
  15. em.persist(customer); 

【编辑推荐】

  1. Eclipse+JBoss+EJB3配置文件发布Session Bean
  2. Eclipse+JBoss+EJB3编写有状态的SessionBean
  3. Eclipse+JBoss+EJB3实现Entity Bean的一对多映射
  4. Eclipse+JBoss+EJB3实现Entity Bean的一对一映射
  5. Eclipse+JBoss+EJB3编写第一个实体Bean程序

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...