【发布时间】:2012-02-27 18:03:01
【问题描述】:
我在尝试通过 manytomany 连接两个表时收到此错误: 错误 [org.hibernate.tool.hbm2ddl.SchemaUpdate] 不成功:更改表 PARAM_TRENDVALUE 添加约束 FK_TrendValue 外键(AreaID、PcID、DeviceID、ValueID)引用 usrIFDBMaster.tblTrdProcessValues 08:44:43,800 错误 [org.hibernate.tool.hbm2ddl.SchemaUpdate] Die 'usrIFDBMaster.tblTrdProcessValues.DeviceID'-Spalte hat nicht denselben Datentyp wie die verweisende 'PARAM_TRENDVALUE.PcID'-Spalte im 'FK_TrendValue'-Fremdschlüssel。
Principaly hibernate 正在尝试映射错误的列。
参数.java:
这是关键:
@EmbeddedId
@AttributeOverrides( {
@AttributeOverride(name = "pcId", column = @Column(name = "PcID", nullable = false)),
@AttributeOverride(name = "unitId", column = @Column(name = "UnitID", nullable = false)),
@AttributeOverride(name = "paramId", column = @Column(name = "ParamID", nullable = false)) })
public ParamId getId() {
return this.id;
}
这是映射:
/**
* @return the connection
*/
@ManyToMany
@ForeignKey(name = "FK_Param")
@JoinTable(
name="PARAM_TRENDVALUE",
inverseJoinColumns={
@JoinColumn(name = "PcID", referencedColumnName = "PcID"),
@JoinColumn(name = "AreaID", referencedColumnName = "AreaID"),
@JoinColumn(name = "DeviceID", referencedColumnName = "DeviceID"),
@JoinColumn(name = "ValueID", referencedColumnName = "ValueID")
}
)
public List<TrendValue> getTrendValues() {
return trendValues;
}
趋势值.java:
这是关键:
@EmbeddedId
@AttributeOverrides( {
@AttributeOverride(name = "pcId", column = @Column(name = "PcID", nullable = false)),
@AttributeOverride(name = "areaId", column = @Column(name = "AreaID", nullable = false)),
@AttributeOverride(name = "deviceId", column = @Column(name = "DeviceID", nullable = false)),
@AttributeOverride(name = "valueId", column = @Column(name = "ValueID", nullable = false))
})
public TrendValueId getId() {
return this.id;
}
这是映射:
/**
* @return the params
*/
@ManyToMany(
mappedBy="trendValues",
targetEntity=Param.class
)
@ForeignKey(name = "FK_TrendValue")
public List<Param> getParams() {
return params;
}
这是我尝试使用的第一个 manytomany,它应该可以工作,我已经尝试过不使用 inversejoincolumns,使用 joincolumns,准确定义“joincolumns/inversejoincolumns”中的表和数据类型,... 不知道还有什么问题。
【问题讨论】:
标签: java hibernate annotations