マルチペアマルチ一方向関連(annotation&xml)

4970 ワード

annotation方式:
一.複数のエンティティクラスを作成するには、次の手順に従います.

@Entity
public class Student{
	private int id;
	private String name;

	@Id
	@GeneratedValue
	public int getId() {
		return id;
	}
	public String getName() {
		return name;
	}
	public void setId(int id) {
		this.id = id;
	}
	public void setName(String name) {
		this.name = name;
	}
}

二.マルチボディクラスの作成

@Entity
public class Teacher {
	private int id;
	private String name;
	private Set<Student> students =new HashSet<Student>();
	@Id
	@GeneratedValue
	public int getId() {
		return id;
	}
	@ManyToMany
	@JoinTable(name="t_s",
	  joinColumns={@JoinColumn(name="teacher_id")},
	  inverseJoinColumns={@JoinColumn(name="student_id")}
	)
	public Set<Student> getStudents() {
		return students;
	}
	public void setStudents(Set<Student> students) {
		this.students = students;
	}
	
	public String getName() {
		return name;
	}
	public void setId(int id) {
		this.id = id;
	}
	public void setName(String name) {
		this.name = name;
	}
}

コメント@ManyToManyを設定し、@JoinTableは中間テーブルを設定し、nameは名前を設定し、joinColumnsは中間テーブル列が現在のクラスIDを指し、inverseJoinColumnsは中間テーブル列が相手のクラスIDを指すように設定する
三.hibernateを設定します.cfg.xml

<mapping class="org.hibernate.tutorial.domain.Teacher"/>
		<mapping class="org.hibernate.tutorial.domain.Student"/>

四.テスト結果

    create table Student (
        studentId integer not null auto_increment,
        name varchar(255),
        primary key (studentId)
    )

    create table Teacher (
        teacherId integer not null auto_increment,
        name varchar(255),
        primary key (teacherId)
    )

    create table t_s (
        teacher_Id integer not null,
        student_Id integer not null,
        primary key (teacher_Id, student_Id)
    )

    alter table t_s 
        add index FK_t2s4kp3kjctswb718yn0ny9ck (student_Id), 
        add constraint FK_t2s4kp3kjctswb718yn0ny9ck 
        foreign key (student_Id) 
        references Student (studentId)

    alter table t_s 
        add index FK_q8pyhjtlr4wxothocdby56ttk (teacher_Id), 
        add constraint FK_q8pyhjtlr4wxothocdby56ttk 
        foreign key (teacher_Id) 
        references Teacher (teacherId)

xml方式:
一.上記のようなエンティティークラスの作成
二.配置hbm.xml

<?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="org.hibernate.tutorial.domain"> 

    <class name="Student" > 
        <id name="id" column="studentId"> 
            <generator class="native"/> 
        </id> 
        <property name="name"></property>
    </class> 

</hibernate-mapping> 

この方は特別な構成は必要ありません
三.Teacherを設定します.hbm.xml

<?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="org.hibernate.tutorial.domain"> 

    <class name="Teacher" > 
        <id name="id" column="teacherId"> 
            <generator class="native"/> 
        </id> 
        <property name="name"></property>
        <set name="students" table="t_s">
        	<key column="teacher_Id"></key>
        	<many-to-many class="org.hibernate.tutorial.domain.Student" column="student_Id"/>
        </set>
    </class> 

</hibernate-mapping> 

本クラスを構成する属性students,tableは中間テーブルを構成するテーブル名,keyは中間テーブル列指向(外部キー)本クラスID,many-to-many配置マッピングクラス,および中間テーブル列指向(外部キー)相手テーブルIDを構成する
四.hibernateを設定します.cfg.xml

<mapping resource="org/hibernate/tutorial/domain/Teacher.hbm.xml"/>
<mapping resource="org/hibernate/tutorial/domain/Student.hbm.xml"/>