Dzq_Boyka 2015-11-28 10:22 采纳率: 0%
浏览 2544
已采纳

java 实体类注解配置问题

我有一个机构实体类,里面有id,orgnName(机构名),parentId(父级机构的id)三个属性
问要如何配置id和parentId的多对一关系?
表里面的数据如下形式:
ID ORGNNAME PARENTID
1 机构 1 0

2 机构 1—1 1(存的是 机构1 的id )
3 机构 1—2 1(存的是 机构1 的id )
求高手解答,不,求 ‘大神’ 解答,跪求!!

  • 写回答

2条回答 默认 最新

  • 毕小宝 博客专家认证 2015-11-28 13:21
    关注

    一对多注解标识在表示多的集合字段上,多对一的注解标识在一的属性上,你定义的实体类本质是自关联的一对多的类。
    按照你描述的需求,使用注解,实例代码如下:

    import java.util.ArrayList;
    import java.util.List;
    
    public class Organization {
        private Integer id;
        private String orgnName;
    
        // 父级机构(即上级机构)
        private Organization parent;
        // 子机构(即所有下级机构)
        private List<Organization> children = new ArrayList<Organization>();
    
        public Integer getId() {
            return id;
        }
    
        public void setId(Integer id) {
            this.id = id;
        }
    
        @Column(nullable = false, unique = true)  
        public String getOrgnName() {
            return orgnName;
        }
    
        public void setOrgnName(String name) {
            this.orgnName = name;
        }
    
        @ManyToOne(fetch = FetchType.LAZY)  
        @JoinColumn(name = "parentId")  
        public Organization getParent() {
            return parent;
        }
    
        public void setParent(Organization parent) {
            this.parent = parent;
        }
    
        @OneToMany(targetEntity = Menu.class, cascade = { CascadeType.ALL }, mappedBy = "parentMenu")  
        @Fetch(FetchMode.SUBSELECT)  
        @OrderBy("id")  
        public List<Organization> getChildren() {
            return children;
        }
    
        public void setChildren(List<Organization> children) {
            this.children = children;
        }
    
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?