Java Hibernate映射:实体ID映射中的重复列

Java Hibernate映射:实体ID映射中的重复列,java,hibernate,hibernate-mapping,Java,Hibernate,Hibernate Mapping,我正在尝试将我的实体映射到SQL Server数据库。 作为一个例外 实体映射中的重复列:com.agency.Hotel列:ID(应使用insert=“false”update=“false”进行映射) 以下是我的酒店地图文件 <?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://

我正在尝试将我的实体映射到SQL Server数据库。 作为一个例外

实体映射中的重复列:com.agency.Hotel列:ID(应使用insert=“false”update=“false”进行映射)

以下是我的酒店地图文件

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
 "-//Hibernate/Hibernate Mapping DTD//EN"
 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 

<hibernate-mapping>
   <class name="com.agency.Hotel" table="Hotels">
      <meta attribute="class-description">
         This class contains the employee detail. 
      </meta>
      <id name="ID" type="int" column="ID">
         <generator class="native"/>
      </id>
      <property name="name" column="Name" type="string"/>
      <property name="star" column="Star" type="int"/>
      <property name="pricePerWeek" column="pricePerWeek" type="double"/>

    <many-to-one name="location" class="com.agency.Location" fetch="select">
            <column name="ID" not-null="true" />
        </many-to-one>

   </class>
</hibernate-mapping>

我已经检查过了,但仍然面临问题。

当我将每个表名的ID更改为tableID时,问题就解决了

例如:

表名:酒店

标识字段:HotelID

由于hibernate存在一些问题或混淆,导致映射不正确,因此所有映射开始正常工作。

应该类似于
表示
Hotel.ID
也是
位置
表中主键列的外键列。由于
Hotel.ID
已定义为
Hotel
表的主键列,因此这没有意义,因此会出现错误。如果真是这样,那么表之间就不会有
关系,而是
关系,因为它们共享主键。
package com.agency;
public class Hotel {
    private int iD = 0;
    private int star = 0;
    private String name = null;
    private double pricePerWeek = 0.0;
    private Location location = null;
    private int locationID = 0;
    public int getID() {
        return iD;
    }
    public void setID(int newID) {
        iD = newID;
    }
    public int getStar() {
        return star;
    }
    public void setStar(int newStar) {
        star = newStar;
    }
    public String getName() {
        return name;
    }
    public void setName(String newName) {
        name = newName;
    }
    public double getPricePerWeek() {
        return pricePerWeek;
    }
    public void setPricePerWeek(double newPricePerWeek) {
        pricePerWeek = newPricePerWeek;
    }
    public Location getLocation() {
        return location;
    }
    public void setLocation(Location newLocation) {
        location = newLocation;
    }
    public int getLocationID() {
        return locationID;
    }
    public void setLocationID(int newLocationID) {
        locationID = newLocationID;
    }
    @Override
    public String toString() {
        return "Hotel " + " [iD: " + getID() + "]" + " [star: " + getStar()
                + "]" + " [name: " + getName() + "]" + " [pricePerWeek: "
                + getPricePerWeek() + "]" + " [locationID: " + getLocationID()
                + "]";
    }
}