`
phyeas
  • 浏览: 161782 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
社区版块
存档分类
最新评论

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();
    }
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics