我想用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"/>
我是休眠新手,我不知道我在哪里做错了。
谢谢