hibernate --------多对多映射

还是用学生和老师来举例子
一个老师可以教多个学生,一个学生也可以有多个老师
(1)先写老师的实体类
package text01;

import java.util.HashSet;
import java.util.Set;

public class Teacher {
private int id;
private String name;
private Set<Student> students = new HashSet<>();

public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public Set<Student> getStudents() {
    return students;
}

public void setStudents(Set<Student> students) {
    this.students = students;
}

}
还有映射文件
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">


<hibernate-mapping package="text01">

<class name="Teacher" table="teacher" >

<id name="id" column="id" type="integer">
<generator class="native"/>
</id>
<property name="name"/>

<set name="students" table="other">

<key column="id"></key>

<many-to-many class="text01.Student" column="num"></many-to-many>
</set>
</class>

</hibernate-mapping>
(2)写学生的实体类以及配置文件

实体类
package text01;

import java.util.HashSet;
import java.util.Set;

public class Student {
private int num;
private String name;
private Set<Teacher> teachers = new HashSet<>();

public int getNum() {
    return num;
}

public void setNum(int num) {
    this.num = num;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public Set<Teacher> getTeachers() {
    return teachers;
}

public void setTeachers(Set<Teacher> teachers) {
    this.teachers = teachers;
}

}

映射文件
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="text01">

<class name="Student" table="student">
    <id name="num" column="num" type="integer">
        <generator class="native" />
    </id>
    <property name="name" />
    <set name="teachers" table="other">
        <key column="num"></key>
        <many-to-many class="text01.Teacher" column="id"></many-to-many>
    </set>
</class>

</hibernate-mapping>

(3)导入配置文件
<?xml version='1.0' encoding='utf-8'?>

<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

<session-factory>

    <!-- Database connection settings -->
    <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
    <property name="connection.url">jdbc:mysql:///hib</property>
    <property name="connection.username">root</property>
    <property name="connection.password">123456</property>
    <!-- Drop and re-create the database schema on startup -->
    <property name="hbm2ddl.auto">create</property>
    <!-- SQL dialect -->
    <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>


    <!-- Echo all executed SQL to stdout -->
    <property name="show_sql">true</property>
    <property name="format_sql">true</property>


    <mapping resource="text01/student.hbm.xml" />
    <mapping resource="text01/teacher.hbm.xml" />


</session-factory>

</hibernate-configuration>

(4)
来测试一下
package text;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;

import text01.Student;
import text01.Teacher;

public class text01 {

public static void main(String[] args) {
    Configuration cfg = new Configuration().configure("hibernate.cfg.xml");
    SessionFactory sessionFactory = cfg.buildSessionFactory();
    Session session = sessionFactory.openSession();
    Transaction ts = session.beginTransaction();

    Teacher teacher = new Teacher();
    Student s1 = new Student();
    Student s2 = new Student();
    s1.setName("666");
    s1.setNum(000);

    s2.setName("6667");
    s2.setNum(0001);
    teacher.setId(1);
    teacher.setName("tom");
    teacher.getStudents().add(s1);
    teacher.getStudents().add(s2);

    session.save(teacher);
    session.save(s1);
    session.save(s2);

    ts.commit();
    session.close();

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,899评论 18 399
  • 对象的状态 Hibernate中对象的状态 : 临时/瞬时状态、持久化状态、游离状态临时状态特点:直接new出来的...
    奋斗的老王阅读 4,430评论 0 49
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,323评论 19 139
  • 集合映射 开发流程:需求分析/数据库设计、项目设计/ 编码/测试/实施部署上线/验收 需求 : 用户购买, 填写地...
    奋斗的老王阅读 4,419评论 0 51
  • 同学,你高中毕业吧? 诶,是啊,高中毕业没事干于是打打工。 那你高考怎么样啊?能上一本吗? 额。。。一本的话不可能...
    海碗咖啡阅读 4,204评论 7 3