Could not determine type for: java.util.List, at table: user, for columns: [org.hibernate.mapping.Column(login_record_list)]

avatar 2018年03月26日10:01:13 7 6316 views
博主分享免费Java教学视频,B站账号:Java刘哥 ,长期提供技术问题解决、项目定制:本站商品点此
在使用 Spring Data JPA 的时候,使用 @OneToMany @ManyToMany 报错如下
Caused by: org.hibernate.MappingException: Could not determine type for: java.util.List, at table: user, for columns: [org.hibernate.mapping.Column(login_record_list)]

at org.hibernate.mapping.SimpleValue.getType(SimpleValue.java:455)
at org.hibernate.mapping.SimpleValue.isValid(SimpleValue.java:422)
at org.hibernate.mapping.Property.isValid(Property.java:226)
at org.hibernate.mapping.PersistentClass.validate(PersistentClass.java:597)
at org.hibernate.mapping.RootClass.validate(RootClass.java:265)
at org.hibernate.boot.internal.MetadataImpl.validate(MetadataImpl.java:329)
at org.hibernate.boot.internal.SessionFactoryBuilderImpl.build(SessionFactoryBuilderImpl.java:459)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:892)
... 23 common frames omitted



解决方案: 


注解要么全部放在字段上,要么全部放在 get 方法上,不能混合使用!

因为我这个类其他的注解都是在标在字段上

所以,这种是正确的
  1. @ManyToMany(cascade = CascadeType.ALL)
  2.   @JoinTable(name = "user_authority",
  3.           joinColumns = {@JoinColumn(name = "user_id", referencedColumnName = "id")},
  4.           inverseJoinColumns = {@JoinColumn(name = "authority_id", referencedColumnName = "id")}
  5.   )
  6.   private List<Authority> authorities;



下面这种就会报错
  1. @OneToMany(mappedBy = "user")
  2.   public List<LoginRecord> getLoginRecordList() {
  3.       return loginRecordList;
  4.   }

只需要改成这样就能成功解决
  1. @OneToMany(mappedBy = "user")
  2. private List<LoginRecord> loginRecordList;





本文地址:https://liuyanzhao.com/7899.html

  • 微信
  • 交流学习,资料分享
  • weinxin
  • 个人淘宝
  • 店铺名:言曌博客咨询部

  • (部分商品未及时上架淘宝)

发表评论

avatar 登录者:匿名
匿名评论,评论回复后会有邮件通知

  

已通过评论:1   待审核评论数:0
  1. avatar Marshal

    博主您好,我是一个Java小白,我也想写一个个人博客,希望您能给我一些建议