Я устанавливаю отношение «многие ко многим», моя таблица соединений JoinTable имеет составной Pk с двумя ключами, проблема в том, что когда я пытаюсь сохранить свою сущность, hibernate продолжает говорить, что он не может преобразовать java.lang.Long
втребуемый тип (User
или Weeks
)
Я пытался изменить атрибуты на примитивы java (long и int, соответственно), но затем hibernate не может установить эти значения в целевой тип (объект).
Я сопоставил отношение следующим образом:
User.java
@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
@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
@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
@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;
И это исключениесгенерировано:
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
сущности, но это исключение сводит меня с ума. Есть идеи?