I have a model called "EventCheckin" which has a ManyToOne mapping to an "Event" and a "User". The PrimaryKey of the "EventCheckin" table is the id of the user and the id of the event. I'm trying to represent this using an "EmbeddedId" in my EventCheckin model but when I attempt to save an EventCheckin it tries to put the user_id and event_id values into the table twice which obviously fails:
Caused by: org.h2.jdbc.JdbcSQLException: Duplicate column name "USER_ID"; SQL statement:
insert into eventCheckin (event_id, user_id, latitude, longitude, user_id, event
_id) values (?,?,?,?,?,?) [42121-158]
EventCheckin class:
@Entity
@Table(name="eventCheckin")
public class EventCheckin extends Model
{
@EmbeddedId public CheckinId id;
@MapsId("userId")
@JoinColumn(name="user_id")
@ManyToOne public User user;
@MapsId("eventId")
@JoinColumn(name="event_id")
@ManyToOne public Event event;
.....
}
CheckinId EmbeddedId class::
@Embeddable
public class CheckinId implements Serializable
{
public Long eventId;
public String userId;
.....
}
And my database table for EventCheckin is defined as this:
create table eventCheckin (
user_id varchar(255) not null,
event_id bigint not null,
latitude float,
longitude float,
constraint pk_eventCheckIn primary key (user_id,event_id),
foreign key (user_id) references user (email),
foreign key (event_id) references event (id)
);
It looks like you try to do same thing via @MapsId and @EmbeddedId. One (working) option is to go for IdClass (equals, hashcode, extra attributes etc are cut away):
@Entity
public class User {
@Id public String id;
}
@Entity
public class Event {
@Id public long id;
}
public class CheckinId implements Serializable {
public Long event;
public String user;
}
@Entity
@IdClass(CheckinId.class)
@Table(name="eventCheckin")
public class EventCheckin {
@Id
@JoinColumn(name="user_id")
@ManyToOne public User user;
@Id
@JoinColumn(name="event_id")
@ManyToOne public Event event;
}