Hibernate的list:多对多

***************
Student.java
***************

package blog.hibernate.domain;

import java.util.ArrayList;
import java.util.List;

public class Student {

    private int id;
    private String name;
    private List<Teacher> teachers = new ArrayList<Teacher>();

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

    public void setTeachers(List<Teacher> teachers) {
        this.teachers = teachers;
    }
    
    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;
    }

    @Override
    public String toString() {
        return "Student{" + "id=" + id + ", name=" + name + '}';
    }
}



************
Student.hbm.xml
************
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="blog.hibernate.domain">
    <class name="Student" table="students">
        <id name="id" column="student_id">
            <generator class="native"></generator>
        </id>
        <property name="name" column="student_name"></property>
                  
         <list name="teachers" table="teacher_student">
             <key column="student_id"></key>
             <list-index column="index" ></list-index>
             <many-to-many class="Teacher" column="teacher_id"></many-to-many>
         </list>
    </class>
</hibernate-mapping>



**************
Teacher.java
**************
package blog.hibernate.domain;

import java.util.ArrayList;
import java.util.List;

public class Teacher {

    private int id;
    private String name;
    private String course;
    private List<Student> students = new ArrayList<Student>();

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

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

    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 String getCourse() {
        return course;
    }

    public void setCourse(String course) {
        this.course = course;
    }

    @Override
    public String toString() {
        return "Teacher{" + "id=" + id + ", name=" + name + ", course=" + course + '}';
    }
}





**************
Teacher.hbm.xml
**************
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="blog.hibernate.domain">
    <class name="Teacher" table="teachers">
        <id name="id" column="teacher_id">
            <generator class="native"></generator>
        </id>
        <property name="name" column="teacher_name"></property>
        <property name="course"></property>
                  
         <list name="students" table="teacher_student">
             <key column="teacher_id" ></key>
             <list-index column="index"></list-index>
            <many-to-many class="Student" column="student_id"></many-to-many>
         </list>
    </class>
</hibernate-mapping>




*****************
hibernate.cfg.xml
*****************

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD//EN"
    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
    <session-factory>
        <property name="hibernate.connection.driver_class">org.gjt.mm.mysql.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/list</property><!-- ///表示连接本机的数据库//localhost:3306 -->
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">1234</property>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
           
        <property name="hibernate.hbm2ddl.auto">create</property>
        <property name="hibernate.show_sql">true</property>
                
        <mapping resource="blog/hibernate/domain/Student.hbm.xml"/>
        <mapping resource="blog/hibernate/domain/Teacher.hbm.xml"/>
        
<!--        <mapping resource="blog/hibernate/domain/Nation.hbm.xml"/>
        <mapping resource="blog/hibernate/domain/City.hbm.xml"/>-->
    </session-factory>    
</hibernate-configuration>




*****************
HibernateUtil.java
*****************
package blog.hibernate;

import java.util.logging.Level;
import java.util.logging.Logger;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;

public final class HibernateUtil {
    
    private static SessionFactory sessionFactory;
    private HibernateUtil(){}
    
    static{
        Configuration cfg = new Configuration();
        sessionFactory =  cfg.configure("hibernate.cfg.xml").buildSessionFactory();
    }
    
    public static SessionFactory getSessionFactory(){
        return sessionFactory;
    }
    
    public static Session getSession(){
        return sessionFactory.openSession();
    }
}


******************
juint test:Many2Many.java
******************
package juint.test;

import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.BeforeClass;
import org.junit.Test;

import blog.hibernate.HibernateUtil;
import blog.hibernate.domain.Student;
import blog.hibernate.domain.Teacher;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
 * list
 * @author Administrator
 */
public class Many2Many {

    @BeforeClass
    public static void setUpBeforeClass() throws Exception {
    }

    @Test
    public void test() {
        add();
        query();
    }

    public void add() {
        Teacher t1 = new Teacher();
        t1.setName("t1");

        Teacher t2 = new Teacher();
        t2.setName("t2");

        List<Teacher> ts = new ArrayList<Teacher>();
        ts.add(t1);
        ts.add(t1);

        Student s1 = new Student();
        s1.setName("s1");

        Student s2 = new Student();
        s2.setName("s2");

        List<Student> ss = new ArrayList<Student>();
        ss.add(s1);
        ss.add(s2);
        
        t1.getStudents().add(s1);
        t1.getStudents().add(s2);
        
        t2.getStudents().add(s1);
        t2.getStudents().add(s2);

//        t1.setStudents(ss);
//        t2.setStudents(ss);
        /*    s1.setTeachers(ts);
        s2.setTeachers(ts);*/


        Session session = null;
        Transaction tx = null;
        try {
            session = HibernateUtil.getSession();
            tx = session.beginTransaction();
            session.save(t1);
            session.save(t2);
            session.save(s1);
            session.save(s2);
            tx.commit();
        } catch (Exception e) {
            Logger.getLogger(Many2Many.class.getName()).log(Level.SEVERE, null, e);
            if (tx != null) {
                tx.rollback();
            }
        } finally {
            if (session != null) {
                session.close();
            }
        }
    }

    public void query() {
        Session session = null;
        try {
            session = HibernateUtil.getSession();
            Teacher teacher = (Teacher) session.get(Teacher.class, 1);
            System.out.println(teacher.getStudents().size());
        } catch (Exception e) {
            Logger.getLogger(Many2Many.class.getName()).log(Level.SEVERE, null, e);
        } finally {
            if (session != null) {
                session.close();
            }
        }
    }
}





posted @ 2012-08-26 11:07  xzf007  阅读(349)  评论(0编辑  收藏  举报