0

我在休眠一对一映射中遇到问题。谷歌了很多,但无法解决。

这里是数据库

以下是我的模型类

公共类用户{

private int userId;
private String userName;
private Address address;

public Address getAddress() {
    return address;
}
public void setAddress(Address address) {
    this.address = address;
}
public int getUserId() {
    return userId;
}
public void setUserId(int userId) {
    this.userId = userId;
}

public String getUserName() {
    return userName;
}
public void setUserName(String userName) {
    this.userName = userName;
}

}

公共类地址{

private int addrId;
private String addr;

public int getAddrId() {
    return addrId;
}
public void setAddrId(int addrId) {
    this.addrId = addrId;
}
public String getAddr() {
    return addr;
}
public void setAddr(String addr) {
    this.addr = addr;
}

}

user.hbm.xml如下:

<class name="User" table="users" schema="dbo" catalog="test">
      <id name="userId" type="int" column="userId" >
        <generator class="assigned"/>
      </id>
  
      <property name="userName">
         <column name="userName" />
      </property>
      
      <one-to-one name="address" property-ref="addrId"  class="Address" cascade="all" />

  </class>

address.hbm.xml 如下,

<class name="ammar.Address" table="Address" schema="dbo" catalog="test">

      <id name="addrId" type="int" column="AddrID" >
        <generator class="assigned"/>
      </id>
  
      <property name="addr">
         <column name="Addr" />
      </property>

  </class>

运行时出现以下异常:

线程“主”org.hibernate.HibernateException 中的异常:无法解析属性:addrId

无需映射即可正常运行。但应用映射时无法检索记录。

hibernate 打印的查询在 DB 中运行得非常好。

4

2 回答 2

2

在 user.hbm.xml 中property-ref="addrId"应该是property-ref="userId"因为 property-ref 是在谈论如何将 Address 连接到 User,而不是相反,这是令人困惑的。您可以省略 property-ref,因为没有它 Address 将通过指向主键的外键找到用户。文档说“如果未指定,则使用关联类的主键”(第 5.1.13 节)。

于 2012-04-09T17:57:41.803 回答
0

我认为这与int价值观无关……我认为它们必须是Integer……

你可以这样改变吗?:

private int addrId;

进入

private Integer addrId;

等等所有int变量...

于 2012-04-09T16:06:55.430 回答