多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區(qū)平臺 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2
您當前位置:首頁 > 數(shù)據(jù)庫 > 數(shù)據(jù)庫應用 > 映射關系級別注解

映射關系級別注解

來源:程序員人生   發(fā)布時間:2016-08-15 08:35:26 閱讀次數(shù):3210次

映照關系級別注解

   1對1單向外鍵

           @OneToOne(cascade=CascadeType.ALL)
@JoinColumn(name="pid",unique=true)
注意:保存時應當先保存外鍵對象,在保存主表對象
   實例:將環(huán)境配置好,所需要的包前邊已提到過,

      學生實體類:
            
package com.oto; import java.util.Date; import javax.persistence.CascadeType; import javax.persistence.Entity;//JPA注解 import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToOne; /* * 學生實體類 */ @Entity public class Students { private int sid; //學號 private IdCard card;//身份證 private String gender;//性別 private Date birthday;//誕生日期 private String major;//專業(yè) public Students(){ } public Students(IdCard card, String gender, Date date, String major) { // super(); this.card = card; this.gender = gender; this.birthday = date; this.major = major; } @Id @GeneratedValue public int getSid() { return sid; } public void setSid(int sid) { this.sid = sid; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public String getMajor() { return major; } public void setMajor(String major) { this.major = major; } @OneToOne(cascade=CascadeType.ALL) @JoinColumn(name="pid",unique=true) public IdCard getCard() { return card; } public void setCard(IdCard card) { this.card = card; } }

身份證實體類:
package com.oto; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import org.hibernate.annotations.GenericGenerator; @Entity public class IdCard { @Id @GeneratedValue(generator="pid") @GenericGenerator(name="pid",strategy="assigned") @Column(length=18) private String pid; //身份證號 private String sname;//姓名 public IdCard(){ } public IdCard(String pid, String sname) { this.pid = pid; this.sname = sname; } public String getPid() { return pid; } public void setPid(String pid) { this.pid = pid; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } }
測試類:
   
package com.oto; import java.util.Date; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.Test; public class TestStudents { @Test public void testShemaExport(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); SchemaExport export = new SchemaExport(config); export.create(true,true); } //往數(shù)據(jù)庫中添加學生數(shù)據(jù) @Test public void addStudents(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); //創(chuàng)建會話 Session session = sessionFactory.getCurrentSession(); //創(chuàng)建事務 Transaction tx = session.beginTransaction(); IdCard card = new IdCard("123456789012345678","豬8戒"); Students stu = new Students(card,"男",new Date(),"計算機"); session.save(card); session.save(stu); tx.commit(); } }

hibernate.cfg.xml中的配置:下面的使用的是同1個配置,下邊的代碼中不再羅列,
       
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration⑶.0.dtd"> <hibernate-configuration> <session-factory> <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> <!-- <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql:///hibernate_struts_stumanager</property> --> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/mypage</property> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">root</property> <property name="hibernate.show_sql">false</property> <property name="hibernate.hbm2ddl.auto">create</property> <property name="current_session_context_class">thread</property> <!-- <mapping class="com.oto.Students"/> <mapping class="com.oto.IdCard"/> --><!-- 1對1單向外鍵關聯(lián) --> <!-- <mapping class="com.oto_11.Students"/> <mapping class="com.oto_11.IdCard"/> --> <!--1對1雙向外鍵關聯(lián) --> <!-- <mapping class="com.mto.Students"/> <mapping class="com.mto.ClassRoom"/> --><!-- 多對1單向外鍵關聯(lián)--> <!-- <mapping class="com.otm.Students"/> <mapping class="com.otm.ClassRoom"/> --><!-- 1對多單向外鍵關聯(lián) --> <!-- <mapping class="com.otm_11.Students"/> <mapping class="com.otm_11.ClassRoom"/> --><!-- 1對多雙向外鍵 --> <!-- <mapping class="com.mtm.Students"/> <mapping class="com.mtm.Teachers"/> --> <!-- 多對多單向外鍵關聯(lián) --> <mapping class="com.mtm_11.Students"/> <mapping class="com.mtm_11.Teachers"/> <!-- 多對多雙向外鍵關聯(lián) --> </session-factory> </hibernate-configuration>

1對1雙向外鍵關聯(lián)

主控方的配置同1對1單向外鍵關聯(lián)
@OneToOne(mappedBy="card")//被控方
雙向關聯(lián),必須設置mappedBy屬性。由于雙向關聯(lián)只能交給1方去控制,不可能在雙方
都設置外鍵保存關聯(lián)關系,否則雙方都沒法保存
實例:
       學生實體類
 
package com.oto_11; import java.util.Date; import javax.persistence.CascadeType; import javax.persistence.Entity;//JPA注解 import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToOne; /* * 學生實體類 */ @Entity public class Students { private int sid; //學號 private IdCard card;//身份證 private String gender;//性別 private Date birthday;//誕生日期 private String major;//專業(yè) public Students(){ } public Students(IdCard card, String gender, Date date, String major) { // super(); this.card = card; this.gender = gender; this.birthday = date; this.major = major; } @Id @GeneratedValue public int getSid() { return sid; } public void setSid(int sid) { this.sid = sid; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public String getMajor() { return major; } public void setMajor(String major) { this.major = major; } @OneToOne(cascade=CascadeType.ALL) @JoinColumn(name="pid",unique=true) public IdCard getCard() { return card; } public void setCard(IdCard card) { this.card = card; } }

身份證實體類:
    
package com.oto_11; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.OneToOne; import org.hibernate.annotations.GenericGenerator; @Entity public class IdCard { @Id @GeneratedValue(generator="pid") @GenericGenerator(name="pid",strategy="assigned") @Column(length=18) private String pid; //身份證號 private String sname;//姓名 @OneToOne(mappedBy="card") private Students stu; public IdCard(){ } public IdCard(String pid, String sname) { this.pid = pid; this.sname = sname; } public Students getStu() { return stu; } public void setStu(Students stu) { this.stu = stu; } public String getPid() { return pid; } public void setPid(String pid) { this.pid = pid; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } }
測試類:
   
package com.oto_11; import java.util.Date; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.Test; public class TestStudents { @Test public void testShemaExport(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); SchemaExport export = new SchemaExport(config); export.create(true,true); } @Test public void addStudents(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); //創(chuàng)建會話 Session session = sessionFactory.getCurrentSession(); //創(chuàng)建事務 Transaction tx = session.beginTransaction(); IdCard card = new IdCard("123456789012345678","豬8戒"); Students stu = new Students(card,"男",new Date(),"計算機"); session.save(card); session.save(stu); tx.commit(); } }

                1對1單向外鍵聯(lián)合主鍵
1對1雙向外鍵聯(lián)合主鍵

 創(chuàng)建主鍵類
主鍵類必須實現(xiàn)serializable接口,重寫hashCode()和equals()方法。
主鍵類
     @Embeddable
實體類
     @EmbeddedId
                

多對1單向外鍵關聯(lián)

       多方持有1方的援用
  @ManyToOne(cascade={CascadeType.ALL},
  fetch=FetchType.EAGER)
  @JoinColumn(name="cid",referencedColumnName="CID")
學生實體類:
 
package com.mto; import java.util.Date; import javax.persistence.CascadeType; import javax.persistence.Entity;//JPA注解 import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.OneToOne; /* * 學生實體類 */ @Entity public class Students { private int sid; //學號 private String gender;//性別 private Date birthday;//誕生日期 private String major;//專業(yè) private ClassRoom classroom; private String sname; public Students(){ } public Students(String sname, String gender, Date date, String major) { // super(); this.sname = sname; this.gender = gender; this.birthday = date; this.major = major; } @Id @GeneratedValue public int getSid() { return sid; } public void setSid(int sid) { this.sid = sid; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public String getMajor() { return major; } public void setMajor(String major) { this.major = major; } @ManyToOne(cascade={CascadeType.ALL},fetch=FetchType.EAGER) @JoinColumn(name="cid",referencedColumnName="CID") public ClassRoom getClassroom() { return classroom; } public void setClassroom(ClassRoom classroom) { this.classroom = classroom; } }

班級實體類:
 
package com.mto; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import org.hibernate.annotations.GenericGenerator; //班級實體類 @Entity public class ClassRoom { @Id @GeneratedValue(generator="cid") @GenericGenerator(name="cid",strategy="assigned") @Column(length=4) private String cid;//班級的編號 private String cname;//班級的名字 public ClassRoom(){ } public ClassRoom(String cid, String cname) { this.cid = cid; this.cname = cname; } public String getCid() { return cid; } public void setCid(String cid) { this.cid = cid; } public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } }
測試類:
  
package com.mto; import java.util.Date; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.Test; public class TestStudents { @Test public void testShemaExport(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); SchemaExport export = new SchemaExport(config); export.create(true,true); } //往數(shù)據(jù)庫中添加學生數(shù)據(jù) @Test public void addStudents(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); //創(chuàng)建會話 Session session = sessionFactory.getCurrentSession(); //創(chuàng)建事務 Transaction tx = session.beginTransaction(); //創(chuàng)建班級對象 ClassRoom c1 = new ClassRoom("0001","軟件工程"); ClassRoom c2 = new ClassRoom("0002","通訊工程"); //創(chuàng)建學生對象 Students s1 = new Students("小王","男",new Date(),"計算機"); Students s2 = new Students("小黃","男",new Date(),"計算機"); Students s3 = new Students("小花","女",new Date(),"計算機"); Students s4 = new Students("小紅","女",new Date(),"計算機"); s1.setClassroom(c1); s2.setClassroom(c1); s3.setClassroom(c2); s4.setClassroom(c2); session.save(c1); session.save(c2); session.save(s1); session.save(s2); session.save(s3); session.save(s4); tx.commit(); } }

1對多單向外鍵關聯(lián)

 1方持有多方的集合
  @OneToMany(cascade={cascadeType.ALL},fetch=FetchType.LAZY)
  @JoinColumn(name="cid")
     實例:
學生實體類:
       
package com.otm; import java.util.Date; import javax.persistence.CascadeType; import javax.persistence.Entity;//JPA注解 import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.OneToOne; /* * 學生實體類 */ @Entity public class Students { private int sid; //學號 private String gender;//性別 private Date birthday;//誕生日期 private String major;//專業(yè) private String sname; public Students(){ } public Students(String sname, String gender, Date date, String major) { // super(); this.sname = sname; this.gender = gender; this.birthday = date; this.major = major; } @Id @GeneratedValue public int getSid() { return sid; } public void setSid(int sid) { this.sid = sid; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public String getMajor() { return major; } public void setMajor(String major) { this.major = major; } }
班級實體類:
         
package com.otm; import java.util.Set; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToMany; import org.hibernate.annotations.GenericGenerator; //班級實體類 @Entity public class ClassRoom { @Id @GeneratedValue(generator="cid") @GenericGenerator(name="cid",strategy="assigned") @Column(length=4) private String cid;//班級的編號 private String cname;//班級的名字 @OneToMany(cascade={CascadeType.ALL},fetch=FetchType.LAZY) @JoinColumn(name="cid") private Set<Students> stus;//1方持有多方的集合 public ClassRoom(){ } public ClassRoom(String cid, String cname) { this.cid = cid; this.cname = cname; } public String getCid() { return cid; } public void setCid(String cid) { this.cid = cid; } public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } public Set<Students> getStus() { return stus; } public void setStus(Set<Students> stus) { this.stus = stus; } }

測試類:
      
package com.otm; import java.util.Date; import java.util.HashSet; import java.util.Set; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.Test; public class TestStudents { @Test public void testShemaExport(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); SchemaExport export = new SchemaExport(config); export.create(true,true); } @Test public void addStudents(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); //創(chuàng)建會話 Session session = sessionFactory.getCurrentSession(); //創(chuàng)建事務 Transaction tx = session.beginTransaction(); //創(chuàng)建班級對象 ClassRoom c1 = new ClassRoom("0001","軟件工程"); ClassRoom c2 = new ClassRoom("0002","通訊工程"); //創(chuàng)建學生對象 Students s1 = new Students("小王","男",new Date(),"計算機"); Students s2 = new Students("小黃","男",new Date(),"計算機"); Students s3 = new Students("小花","女",new Date(),"計算機"); Students s4 = new Students("小紅","女",new Date(),"計算機"); Set<Students> set1 = new HashSet<Students>(); set1.add(s1); set1.add(s2); Set<Students> set2 = new HashSet<Students>(); set2.add(s3); set2.add(s4); session.save(s1); session.save(s2); session.save(s3); session.save(s4); session.save(c1); session.save(c2); tx.commit(); } }

1對多雙向外鍵關聯(lián)

多方:多方持有1方的援用
@ManyToOne(cascade={CascadeType.ALL},fetch=FetchType.EAGER)
@JoinColumn(name="cid")
1方:1方持有多方的集合
@OneToMany(cascade={CascadeType.ALL},fetch=FetchType.LAZY)
@JoinColumn(name="cid")
        實例:
      
package com.otm_11; import java.util.Date; import javax.persistence.CascadeType; import javax.persistence.Entity;//JPA注解 import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.OneToOne; /* * 學生實體類 */ @Entity public class Students { private int sid; //學號 private String gender;//性別 private Date birthday;//誕生日期 private String major;//專業(yè) private String sname;//姓名 private ClassRoom classroom; public Students(){ } public Students(String sname, String gender, Date date, String major) { // super(); this.sname = sname; this.gender = gender; this.birthday = date; this.major = major; } @Id @GeneratedValue public int getSid() { return sid; } public void setSid(int sid) { this.sid = sid; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public String getMajor() { return major; } public void setMajor(String major) { this.major = major; } @ManyToOne(cascade={CascadeType.ALL},fetch=FetchType.EAGER) @JoinColumn(name="cid") public ClassRoom getClassroom() { return classroom; } public void setClassroom(ClassRoom classroom) { this.classroom = classroom; } }

班級實體類:
  
package com.otm_11; import java.util.Set; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToMany; import org.hibernate.annotations.GenericGenerator; //班級實體類 @Entity public class ClassRoom { @Id @GeneratedValue(generator="cid") @GenericGenerator(name="cid",strategy="assigned") @Column(length=4) private String cid;//班級的編號 private String cname;//班級的名字 @OneToMany(cascade={CascadeType.ALL},fetch=FetchType.LAZY) @JoinColumn(name="cid") private Set<Students> stus;//1方持有多方的集合 public ClassRoom(){ } public ClassRoom(String cid, String cname) { this.cid = cid; this.cname = cname; } public String getCid() { return cid; } public void setCid(String cid) { this.cid = cid; } public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } public Set<Students> getStus() { return stus; } public void setStus(Set<Students> stus) { this.stus = stus; } }
測試類:
 
package com.mto_11; import java.util.Date; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.Test; import com.otm_11.ClassRoom; import com.otm_11.Students; public class TestStudents { @Test public void testShemaExport(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); SchemaExport export = new SchemaExport(config); export.create(true,true); } @Test public void addStudents(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); //創(chuàng)建會話 Session session = sessionFactory.getCurrentSession(); //創(chuàng)建事務 Transaction tx = session.beginTransaction(); //創(chuàng)建班級對象 ClassRoom c1 = new ClassRoom("0001","軟件工程"); ClassRoom c2 = new ClassRoom("0002","通訊工程"); //創(chuàng)建學生對象 Students s1 = new Students("小王","男",new Date(),"計算機"); Students s2 = new Students("小黃","男",new Date(),"計算機"); Students s3 = new Students("小花","女",new Date(),"計算機"); Students s4 = new Students("小紅","女",new Date(),"計算機"); s1.setClassroom(c1); s2.setClassroom(c1); s3.setClassroom(c2); s4.setClassroom(c2); session.save(c1); session.save(c2); session.save(s1); session.save(s2); session.save(s3); session.save(s4); tx.commit(); } }

多對多單向外鍵關聯(lián)

 其中1個多方持有另外一個多方的集合對象
 創(chuàng)建中間表
 @MantToMany
 @JoinTable(
     name="teachers_students",
     joinColumns={@JoinColumn(name="sid")},inverseJoinColumns={@JoinColumn(name="tid")}
 )
實例:
學生實體類:
package com.mtm; import java.util.Date; import java.util.Set; import javax.persistence.CascadeType; import javax.persistence.Entity;//JPA注解 import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.JoinTable; import javax.persistence.ManyToMany; import javax.persistence.ManyToOne; import javax.persistence.OneToOne; /* * 學生實體類 */ @Entity public class Students { private int sid; //學號 private String gender;//性別 private Date birthday;//誕生日期 private String major;//專業(yè) private String sname;//學生姓名 private Set<Teachers> teachers; //學生持有教師的集合 public Students(){ } public Students(String sname, String gender, Date date, String major) { // super(); this.sname = sname; this.gender = gender; this.birthday = date; this.major = major; } @Id @GeneratedValue public int getSid() { return sid; } public void setSid(int sid) { this.sid = sid; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public String getMajor() { return major; } public void setMajor(String major) { this.major = major; } @ManyToMany @JoinTable( name="teachers_students", joinColumns={@JoinColumn(name="sid")}, inverseJoinColumns={@JoinColumn(name="tid")} ) public Set<Teachers> getTeachers() { return teachers; } public void setTeachers(Set<Teachers> teachers) { this.teachers = teachers; } }

老師實體類:
 
package com.mtm; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import org.hibernate.annotations.GenericGenerator; //教師實體類 @Entity public class Teachers { @Id @GeneratedValue(generator="tid") @GenericGenerator(name="tid",strategy="assigned") @Column(length=4) private String tid;//教師id private String tname;//教師名字 public Teachers(){ } public Teachers(String tid, String tname) { // super(); this.tid = tid; this.tname = tname; } public String getTid() { return tid; } public void setTid(String tid) { this.tid = tid; } public String getTname() { return tname; } public void setTname(String tname) { this.tname = tname; } }

測試類:
package com.mtm; import java.util.Date; import java.util.HashSet; import java.util.Set; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.Test; public class TestStudents { @Test public void testShemaExport(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); SchemaExport export = new SchemaExport(config); export.create(true,true); } @Test public void addStudents(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); Session session = sessionFactory.getCurrentSession(); Transaction tx = session.beginTransaction(); //創(chuàng)建教師對象 Teachers t1 = new Teachers("0001","張老師"); Teachers t2 = new Teachers("0002","黃老師"); Teachers t3 = new Teachers("0003","李老師"); Teachers t4 = new Teachers("0004","王老師"); Students s1 = new Students("張3","男",new Date(),"計算機"); Students s2 = new Students("李4","男",new Date(),"計算機"); Students s3 = new Students("王5","女",new Date(),"通訊"); Students s4 = new Students("趙6","女",new Date(),"通訊"); Set<Teachers> set1 = new HashSet<Teachers>(); set1.add(t1); set1.add(t2); Set<Teachers> set2 = new HashSet<Teachers>(); set2.add(t3); set2.add(t4); Set<Teachers> set3 = new HashSet<Teachers>(); set3.add(t1); set3.add(t3); set3.add(t4); Set<Teachers> set4 = new HashSet<Teachers>(); set4.add(t2); set4.add(t3); set4.add(t4); s1.setTeachers(set1); s2.setTeachers(set2); s3.setTeachers(set3); s4.setTeachers(set4); session.save(t1); session.save(t2); session.save(t3); session.save(t4); session.save(s1); session.save(s2); session.save(s3); session.save(s4); tx.commit(); } }

多對多雙向外鍵關聯(lián)

雙方持有對方的集合對象,其中1方設置
 //教師類
 @ManyToMany(mappedBy="teachers")
 另外一方
 //學生類
 @ManyToMany
 @JoinTable(
    name="teachers_students",
    joinColumns={@JoinColumn(name="sid")},
    inverseJoinColumns={@JoinColumn(name="tid")}
 )
實例:
學生實體類:
 
package com.mtm_11; import java.util.Date; import java.util.Set; import javax.persistence.CascadeType; import javax.persistence.Entity;//JPA注解 import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.JoinTable; import javax.persistence.ManyToMany; import javax.persistence.ManyToOne; import javax.persistence.OneToOne; /* * 學生實體類 */ @Entity public class Students { private int sid; //學號 private String gender;//性別 private Date birthday;//誕生日期 private String major;//專業(yè) private String sname;//學生姓名 private Set<Teachers> teachers; //學生持有教師的集合 public Students(){ } public Students(String sname, String gender, Date date, String major) { // super(); this.sname = sname; this.gender = gender; this.birthday = date; this.major = major; } @Id @GeneratedValue public int getSid() { return sid; } public void setSid(int sid) { this.sid = sid; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public String getMajor() { return major; } public void setMajor(String major) { this.major = major; } @ManyToMany @JoinTable( name="teachers_students", joinColumns={@JoinColumn(name="sid")}, inverseJoinColumns={@JoinColumn(name="tid")} ) public Set<Teachers> getTeachers() { return teachers; } public void setTeachers(Set<Teachers> teachers) { this.teachers = teachers; } }
老師實體類:
  
package com.mtm_11; import java.util.Set; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.ManyToMany; import org.hibernate.annotations.GenericGenerator; //教師實體類 @Entity public class Teachers { @Id @GeneratedValue(generator="tid") @GenericGenerator(name="tid",strategy="assigned") @Column(length=4) private String tid;//教師id private String tname;//教師名字 @ManyToMany(mappedBy="teachers") private Set<Students> stus;//教師持有學生的集合 public Teachers(){ } public Teachers(String tid, String tname) { // super(); this.tid = tid; this.tname = tname; } public String getTid() { return tid; } public void setTid(String tid) { this.tid = tid; } public String getTname() { return tname; } public void setTname(String tname) { this.tname = tname; } }
測試類:
  
package com.mtm_11; import java.util.Date; import java.util.HashSet; import java.util.Set; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.hibernate.tool.hbm2ddl.SchemaExport; import org.junit.Test; public class TestStudents { @Test public void testShemaExport(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); SchemaExport export = new SchemaExport(config); export.create(true,true); } @Test public void addStudents(){ //創(chuàng)建hibernate配置對象 Configuration config = new Configuration().configure(); //創(chuàng)建服務注冊對象 ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); //生成SessionFactory SessionFactory sessionFactory = config.buildSessionFactory(serviceRegistry); Session session = sessionFactory.getCurrentSession(); Transaction tx = session.beginTransaction(); //創(chuàng)建教師對象 Teachers t1 = new Teachers("0001","張老師"); Teachers t2 = new Teachers("0002","黃老師"); Teachers t3 = new Teachers("0003","李老師"); Teachers t4 = new Teachers("0004","王老師"); Students s1 = new Students("張3","男",new Date(),"計算機"); Students s2 = new Students("李4","男",new Date(),"計算機"); Students s3 = new Students("王5","女",new Date(),"通訊"); Students s4 = new Students("趙6","女",new Date(),"通訊"); Set<Teachers> set1 = new HashSet<Teachers>(); set1.add(t1); set1.add(t2); Set<Teachers> set2 = new HashSet<Teachers>(); set2.add(t3); set2.add(t4); Set<Teachers> set3 = new HashSet<Teachers>(); set3.add(t1); set3.add(t3); set3.add(t4); Set<Teachers> set4 = new HashSet<Teachers>(); set4.add(t2); set4.add(t3); set4.add(t4); s1.setTeachers(set1); s2.setTeachers(set2); s3.setTeachers(set3); s4.setTeachers(set4); session.save(t1); session.save(t2); session.save(t3); session.save(t4); session.save(s1); session.save(s2); session.save(s3); session.save(s4); tx.commit(); } }
這里羅列了幾個簡單的例子,大神直接略過啊~~~~
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 五月婷网 | 精品videosex性欧美 | 欧美野外多人交3 | 亚洲精品福利一区二区 | 男人午夜小视频 | 国产成人精品日本亚洲专 | 永久免费毛片在线播放 | 亚洲福利视频一区二区 | 久久综合久久久 | 国产亚洲精品福利片 | 美女福利影院 | 性丰满妇女free性性性 | 欧美性猛交xxxx黑人猛交 | 国产亚洲欧美一区二区三区 | www.日本高清视频.com | www.狠狠艹| 亚洲黄色一区二区 | 五月天最新网站 | 国产三区视频在线观看 | 免费一级欧美片片线观看 | 欧美黑人巨大xxxx猛交 | a级毛毛片看久久 | 有码在线视频 | 亚洲欧洲日韩国产一区二区三区 | 国产内地激情精品毛片在线一 | 极品久久 | 宇都宫紫苑在线播放ed2k | 国产精品免费视频一区一 | www视频免费观看 | 日韩理论片在线观看 | 日本337p| 国产毛片儿 | 成人中文字幕在线高清 | 欧美一区二区在线免费观看 | 日韩一区二区三区四区五区 | 欧美一区二区在线观看免费网站 | 久久精品国产74国产 | 欧美一区二区在线观看免费网站 | 一区二区精品久久 | 午夜影院在线观看 | 国产精品jizz在线观看软件 |