日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線(xiàn)溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
Eclipse+JBoss+EJB3實(shí)現(xiàn)EntityBean的多對(duì)多映射

在EJB3中需要使用@ManyToMany對(duì)封裝多對(duì)多關(guān)系的字段或getter方法進(jìn)行注釋。先看看下面的表:

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括奇臺(tái)網(wǎng)站建設(shè)、奇臺(tái)網(wǎng)站制作、奇臺(tái)網(wǎng)頁(yè)制作以及奇臺(tái)網(wǎng)絡(luò)營(yíng)銷(xiāo)策劃等。多年來(lái),我們專(zhuān)注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,奇臺(tái)網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶(hù)以成都為中心已經(jīng)輻射到奇臺(tái)省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶(hù)的支持與信任!

圖1  t_addresses表

t_addresses表和t_customers表是多對(duì)多的關(guān)系。需要使用一個(gè)關(guān)聯(lián)表來(lái)描述這種關(guān)系,關(guān)聯(lián)表的結(jié)構(gòu)如下圖所示。

t_customers_addresses

在Customer類(lèi)中定義一個(gè)Collection < ADDRESS>類(lèi)型的字段(addresses),用于保存與該Customer對(duì)象相對(duì)應(yīng)的多個(gè)Address對(duì)象,代碼如下:

 
 
 
 
  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表的連接字段關(guān)系。  
  42.     Address類(lèi)的代碼如下:  
  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. }  

由于是多對(duì)多的關(guān)系,因此,在Address類(lèi)中需要定義一個(gè)Collection類(lèi)型的字段(customers)用來(lái)保存與該Address對(duì)象相對(duì)應(yīng)的Customer對(duì)象。getCustomers方法也需要使用@ManyToMany進(jìn)行注釋??梢允褂孟旅娲a進(jìn)行測(cè)試:

 
 
 
 
  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("中國(guó)");   
  7. address.setPostCode("12345678");  
  8. addresses.add(address);  
  9. address = new entity.Address();  
  10. address.setAddressLine("address2");  
  11. address.setCountry("美國(guó)");   
  12. address.setPostCode("4321");  
  13. addresses.add(address);  
  14. customer.setAddresses(addresses);  
  15. em.persist(customer); 

網(wǎng)站名稱(chēng):Eclipse+JBoss+EJB3實(shí)現(xiàn)EntityBean的多對(duì)多映射
當(dāng)前URL:http://www.5511xx.com/article/djhohgg.html