Hibernate HBM Mapping Problem - PullRequest
       17

Hibernate HBM Mapping Problem

2 голосов
/ 26 марта 2011

У меня есть следующие три класса:

public class Student {
    private Integer studentId;
    private StudentSchool studentSchool;
    private School school;

    public Integer getStudentId() {
        return studentId;
    }
    public void setStudentId(Integer studentId) {
        this.studentId = studentId;
    }
    public StudentSchool getStudentSchool() {
        return studentSchool;
    }
    public School getSchool() {
        return school;
    }
    public void setSchool(School school) {
        this.school = school;
    }
}

public class StudentSchool {
    private Student student;
    private School school;  

    public Student getStudent() {
        return student;
    }
    public void setStudent(Student student) {
        this.student = student;
    }
    public School getSchool() {
        return school;
    }
    public void setSchool(School school) {
        this.school = school;
    }
}

public class School {
    private Integer schoolId;
    private Set allStudents;

    public Integer getSchoolId() {
        return schoolId;
    }
    public void setSchoolId(Integer schoolId) {
        this.schoolId = schoolId;
    }
    public Set getAllStudents() {
        return allStudents;
    }
    public void setAllStudents(Set allStudents) {
        this.allStudents = allStudents;
    }
}

У меня есть следующий DDL:

create table Student (StudentId Integer);
create table StudentSchool (SchoolId Integer, StudentId Integer);
create table School (SchoolId Integer Primary Key);

У меня есть следующие файлы HBM:

School.hbm.xml

<hibernate-mapping>
    <class name="School" table="School">
        <property name="schoolId" type="integer" />
        <set name="allStudents" table="StudentSchool" fetch="join">
            <key column="schoolId" />
            <composite-element class="StudentSchool">
                <parent name="school"/>
                <many-to-one name="student" column="studentId" not-null="true" class="Student" />
            </composite-element>
        </set>
    </class>
</hibernate-mapping>

Student.hbm.xml

<hibernate-mapping>
    <class name="Student" table="Student">
        <property name="studentId" type="integer" />
        <one-to-one name="studentSchool" class="StudentSchool" />
        <!-- <one-to-one name="school" class="School" /> -->
    </class>
</hibernate-mapping>

Когда я пытаюсь запросить объект Student на основе школы, я получаю следующее исключение (хотя у меня есть класс с именем «StudentSchool», скомпилированный в моем пути к классам):

org.hibernate.MappingException: persistent class not known: StudentSchool

Если я раскомментирую сопоставление «один к одному» с «School» и закомментирую сопоставление «один к одному» с «studentSchool», я получу следующее исключение:

<AST>:1:143: unexpected AST node: : java.lang.NullPointerException

У кого-нибудь есть идеи о том, что я сделал не так с моим hbm mapping? Спасибо!

1 Ответ

3 голосов
/ 26 марта 2011

Вы должны дать полное имя своим классам в файлах hbm.

как somepackage.StudentSchool

РЕДАКТИРОВАТЬ: если все находятся в одном пакете, попробуйте добавить это

<hibernate-mapping>
    <class name="Student" table="Student">
        <property name="studentId" type="integer" />
        <one-to-one name="studentSchool" class="StudentSchool" property-ref="student"/>
        <!-- <one-to-one name="school" class="School" property-ref="student"/> -->
    </class>
</hibernate-mapping>
...