1

我想用hibernate写一个简单的多对一ORM。我有两张桌子,用户和位置。位置包含我想在用户类中引用的国家名称之一。

public class User extends  BusinessBaseImpl implements UserInterface{

private String id;
private String firstName;
private String lastName;
private String mobileNumber;
private Location location;
private String email;
private String password;
private String type;

public String getFirstName() {
    return firstName;
}
public void setFirstName(String firstName) {
    this.firstName = firstName;
    makeDirty();
}
public String getLastName() {
    return lastName;
}
public void setLastName(String lastName) {
    this.lastName = lastName;
    makeDirty();
}
public String getMobileNumber() {
    return mobileNumber;
}
public void setMobileNumber(String mobileNumber) {
    this.mobileNumber = mobileNumber;
    makeDirty();
}
public Location getLocation() {
    return location;
}
public void setLocation(Location location) {
    this.location = location;
    makeDirty();
}
public String getEmail() {
    return email;
}
public void setEmail(String email) {
    this.email = email;
    makeDirty();
}
public String getPassword() {
    return password;
}
public void setPassword(String password) {
    this.password = password;
    makeDirty();
}
public String getType() {
    return type;
}
public void setType(String type) {
    this.type = type;
    makeDirty();
}
public String getId() {
    return id;
}
@SuppressWarnings("unused")
private void setId(String id){
    this.id = id;
}
/**
 *
 * Private constructor.
 */
public User(){
    this.id = CoreService.getUID();
    this.isNew = true;
    this.isDirty = false;
}

}

休眠配置文件

<hibernate-mapping>
<class name="pspl.assignment.businessimpl.User" table="user">
    <id name="id" type="string" column="id">
        <generator class="assigned"></generator>
    </id>

    <property name="firstName">
        <column name="firstname" />
    </property>
    <property name="lastName">
        <column name="lastname" />
    </property>
    <property name="email">
        <column name="email" />
    </property>
    <property name="mobileNumber">
        <column name="mobilenumber" />
    </property>
    <many-to-one name="location" class="pspl.assignment.businessimpl.Location" column="location"  >
    </many-to-one>  
    <property name="password">
        <column name="password" />
    </property>
    <property name="type">
        <column name="type" />
    </property>
</class>

位置类

public class Location extends BusinessBaseImpl {

private String id;
private String contryName;

public String getId() {
    return id;
}

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

public String getContryName() {
    return contryName;
}

public void setContryName(String contryName) {
    this.contryName = contryName;
}

public Location(){
    this.setId(CoreService.getUID());
    this.isDirty = false;
    this.isNew = true;
}

public static Location createNew(){
    return new Location();
}

}

当我在用户类上执行测试用例时,我得到以下异常

org.hibernate.MappingException: Could not determine type for: pspl.assignment.businessimpl.Location, at table: user, for columns: [org.hibernate.mapping.Column(location)]
at org.hibernate.mapping.SimpleValue.getType(SimpleValue.java:269)
at org.hibernate.mapping.SimpleValue.isValid(SimpleValue.java:253)
at org.hibernate.mapping.Property.isValid(Property.java:185)
at org.hibernate.mapping.PersistentClass.validate(PersistentClass.java:440)
at org.hibernate.mapping.RootClass.validate(RootClass.java:192)..............

位置映射文件

<hibernate-mapping>
<class name="pspl.assignment.businessimpl.Location" table="location">
    <id name="id" type="string" column="id"></id>
    <property name="contryName"><column name="contryname"/> </property>
</class> 

休眠配置文件

<hibernate-configuration>

  <mapping resource="location.hbm.xml"/>
  <mapping resource="user.hbm.xml"/>

我是休眠新手,我不知道我在哪里做错了。

谢谢

4

0 回答 0