fhyw 2010-12-28 09:58
浏览 255
已采纳

Hibernate多对一映射文件的问题

我在配映射文件时遇到A表外键名和B表的主键名不同,不知道如何写hbm.xml了。如我有业务表A, 里面有个外键creatorID, 关联到StaffInfo的主键staffID,那么我在A表中加入属性StaffInfo creator。问题是在hbm.xml中如何让staff.staffID对应A表的creatorID呢?我按照reference doc里面的配法

<class name="A">
<id name="id" column="AID">
<generator class="native"/>
</id>
<many-to-one name="staff"
column="staffID"
unique="true"
not-null="true"/>
</class>

这样程序调用setCreator()或者getCreator()时会报错。由于StaffInfo是框架中的表,所以我无权更改这个表的column,而在A表内,由于还有其他的column也是staffID的,所以也不可能把creator改成staffID。那么这个问题该如何解决呢?
  • 写回答

4条回答 默认 最新

  • oxcow 2010-12-28 10:08
    关注

    many里的column应该是many中的外键而不是one端的主键

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 求学软件的前人们指明方向🥺
  • ¥50 如何增强飞上天的树莓派的热点信号强度,以使得笔记本可以在地面实现远程桌面连接
  • ¥15 MCNP里如何定义多个源?
  • ¥20 双层网络上信息-疾病传播
  • ¥50 paddlepaddle pinn
  • ¥20 idea运行测试代码报错问题
  • ¥15 网络监控:网络故障告警通知
  • ¥15 django项目运行报编码错误
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services