jpa实现表自连

表自连实际上就是one to one的关系。比如书籍类型。类型有父类型。那父类型如何表示呢。在java中应当这样写:
public class BookType  {
    
private Long id;
    
private String name;
    
    
private BookType parent;
        
//getter && setter
}
但如果这个是一个JPA类就出问题了。因为parent没有写注释。在jpa自动创建表是会认为这是一个字节类型的。所以还应该为parent些上一个注释。既然是自连。应该写@OneToOne
这里就要注意了。OneToOne不能写其他属性,比如不能这样写
@OneToOne(targetClass=BookType.class)
这样的话在系统自动生成数据表时会报错。也不能加 @JoinColumn。唯一的办法就是只要@OneToOne。其他什么都不写。这样就不会报错了。
代码如下:
public class BookType  {
    
private Long id;
    
private String name;
    
    @OneToOne
    
private BookType parent;
        
//getter && setter
}

另外:如果想不让某个属性不被转换成数据库字段。需要在此属性的getter方法上加@Transient注释。比如BookType的fullName属性。
例子:
    /**
     * 获取包括父节点名称的全部路径
     * 
@return
     
*/
    @Transient
    
public String getFullName(){
        StringBuffer buffer
=new StringBuffer("");
        
if(parent!=null){
            buffer.append(parent.getFullName());
            buffer.append(
"-");
        }
        buffer.append(name);
        
return buffer.toString();
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值