首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >未能将“java.lang.Integer”类型的属性值转换为所需类型

未能将“java.lang.Integer”类型的属性值转换为所需类型
EN

Stack Overflow用户
提问于 2019-04-25 17:51:07
回答 1查看 2.2K关注 0票数 0

我正在设置多个关系,我的联接表JoinTable有一个带有两个键的复合Pk,问题是当我试图持久化我的实体hibernate时,他总是说他不能将java.lang.Long转换成所需的类型(UserWeeks)

我尝试将属性更改为java原语(分别为long和int ),但hibernate无法将此值设置为目标类型(对象)。

我把这种关系描绘成这样:

User.java

代码语言:javascript
运行
复制
@Column(name="id", nullable=false)  
@Id 
@GeneratedValue(generator="USER_ID_GENERATOR")  
@org.hibernate.annotations.GenericGenerator(name="USER_ID_GENERATOR", strategy="native")    
private long id;

@OneToMany(mappedBy="user", targetEntity=com.ti.project.Model.JoinTable.class)  @org.hibernate.annotations.Cascade({org.hibernate.annotations.CascadeType.SAVE_UPDATE, org.hibernate.annotations.CascadeType.LOCK}) 
@org.hibernate.annotations.LazyCollection(org.hibernate.annotations.LazyCollectionOption.TRUE)  
private java.util.Set jointable = new java.util.HashSet();

Weeks.java

代码语言:javascript
运行
复制
@Column(name="week_id", nullable=false) 
@Id 
@GeneratedValue(generator="WEEK_ID_GENERATOR")  
@org.hibernate.annotations.GenericGenerator(name="WEEK_ID_GENERATOR", strategy="native")    
private int week_id;

@OneToMany(mappedBy="week",targetEntity=com.ti.project.Model.JoinTable.class)   
@org.hibernate.annotations.Cascade({org.hibernate.annotations.CascadeType.SAVE_UPDATE, org.hibernate.annotations.CascadeType.LOCK}) 
@org.hibernate.annotations.LazyCollection(org.hibernate.annotations.LazyCollectionOption.TRUE)  
private java.util.Set jointable = new java.util.HashSet();

JoinTable.java

代码语言:javascript
运行
复制
@PrimaryKeyJoinColumn       
@ManyToOne(targetEntity=com.ti.project.Model.User.class, fetch=FetchType.LAZY)  
@org.hibernate.annotations.Cascade({org.hibernate.annotations.CascadeType.LOCK})    
@JoinColumns(value={ @JoinColumn(name="user_id", referencedColumnName="id", nullable=false) }, foreignKey=@ForeignKey(name="FKuser_su465470"))  
private com.ti.project.Model.User user;

@Column(name="user_id", nullable=false, insertable=false, updatable=false)  
@Id     
@org.hibernate.annotations.GenericGenerator(name="USERID_GENERATOR", strategy="foreign", parameters=@org.hibernate.annotations.Parameter(name="property", value="user"))    
private long userId;

@PrimaryKeyJoinColumn   
@ManyToOne(targetEntity=com.ti.project.Model.Weeks.class, fetch=FetchType.LAZY) 
@org.hibernate.annotations.Cascade({org.hibernate.annotations.CascadeType.LOCK})    
@JoinColumns(value={ @JoinColumn(name="week_id", referencedColumnName="week_id", nullable=false) }, foreignKey=@ForeignKey(name="FKweek_su338979")) 
private com.ti.project.Model.Weeks week;

@Column(name="week_id", nullable=false, insertable=false, updatable=false)  
@Id 
@GeneratedValue(generator="WEEKID_GENERATOR")   
@org.hibernate.annotations.GenericGenerator(name="WEEKID_GENERATOR", strategy="foreign", parameters=@org.hibernate.annotations.Parameter(name="property", value="week"))    
private int weekId;

JoinTablePK.java

代码语言:javascript
运行
复制
@ManyToOne(targetEntity=com.ti.project.Model.User.class, fetch=FetchType.LAZY)  
@org.hibernate.annotations.Cascade({org.hibernate.annotations.CascadeType.LOCK})    
@JoinColumns(value={ @JoinColumn(name="user_id", referencedColumnName="id", nullable=false) }, foreignKey=@ForeignKey(name="FKuser_su465470"))  
private com.ti.project.Model.User user;

@ManyToOne(targetEntity=com.ti.project.Model.Weeks.class, fetch=FetchType.LAZY) 
@org.hibernate.annotations.Cascade({org.hibernate.annotations.CascadeType.LOCK})    
@JoinColumns(value={ @JoinColumn(name="week_id", referencedColumnName="week_id", nullable=false) }, foreignKey=@ForeignKey(name="FKweek_su338979")) 
private com.ti.project.Model.Weeks week;

这是生成的异常:

代码语言:javascript
运行
复制
Failed to convert property value of type 'java.lang.Integer' to required type 'com.ti.project.Model.Weeks' for property 'week'; nested exception is java.lang.IllegalStateException: Cannot convert value of type 'java.lang.Integer' to required type 'com.ti.project.Model.Weeks' for property 'week': no matching editors or conversion strategy found

我希望持久化这个JoinTable实体,但是这个异常让我疯狂了吗?

EN

Stack Overflow用户

发布于 2019-04-25 20:45:51

你的地图都是错的。您有@OneToMany和@ManyToOne映射。你为什么用中间的桌子?您只需要@ManyToMany关系中的中间表。删除JoinTable.class,因为代码中没有引用。

另一个问题是您的targetClass。查看如何映射@OneToMany和@ManyToOne关系。一定很容易。

https://www.baeldung.com/hibernate-one-to-many

祝好运!

票数 -1
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55855053

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档