凌晨几点 2013-08-31 07:25 采纳率: 0%
浏览 895

表的设置,和hibernate的映射

我想设置这样的一个表,他有一个外键,这个外键可以对应多个表,
比如(A表,B表,C表)有一个判断类型字段type,我想让这个外键可以对应多个表的主键,
比如:
type等于1时此时的外键对应的是A表的主键,类型type等于2时此时的外键对应的是B表的主键。请问怎么设置,

如果使用hibernate来映射的话,怎么写映射文件?

  • 写回答

1条回答

  • ChatGPTᴼᴾᴱᴺᴬᴵ 2023-01-16 15:50
    关注

    这种情况可以使用多态外键关系来实现。在 Hibernate 中,可以使用 @ManyToOne 的 targetEntity 属性来实现多态外键关系。


    例如,在你的另外三个表 A,B,C 中都有一个 type 字段。


    那么在表 D 中,可以这样设置外键关系:

    @ManyToOne(targetEntity = A.class)
    @JoinColumn(name = "a_id", referencedColumnName = "id", insertable = false, updatable = false)
    private A a;
    
    @ManyToOne(targetEntity = B.class)
    @JoinColumn(name = "b_id", referencedColumnName = "id", insertable = false, updatable = false)
    private B b;
    
    @ManyToOne(targetEntity = C.class)
    @JoinColumn(name = "c_id", referencedColumnName = "id", insertable = false, updatable = false)
    private C c;
    

    在这里,表 D 的外键关系对应 A, B, C 三个表的主键,根据 type 字段来判断对应哪个表的主键,你可以在你的业务逻辑中来完成这个判断。

    评论

报告相同问题?

悬赏问题

  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler