繁体   English   中英

@ManyToMany连接表失败

[英]@ManyToMany Join Table fails

我遇到了一个我无法解决的问题。

环境:

  • MySQL 5
  • OS X
  • 休眠4.1
  • 春季3.1
  • Spring Data JPA

我在ManyToMany关系中有两个实体。 我为此使用带有外键的Join表。 这是我的实体(为简洁起见进行了修改):

@Entity
public class Employee  {
  @Id
  @GeneratedValue( strategy = GenerationType.AUTO )
  private Long employeeId;

@ManyToMany( cascade = CascadeType.ALL, fetch = FetchType.EAGER, targetEntity = Office.class )
@JoinTable( name = "EmployeeOfficeJoin", joinColumns = { @JoinColumn( name = "EmployeeId", nullable = false, updatable = false ) }, inverseJoinColumns = { @JoinColumn( name = "OfficeId", nullable = false, updatable = false ) } )
private List<Office> offices = new ArrayList<Office>();
}

@Entity
public class Office {

@Id
@GeneratedValue( strategy = GenerationType.AUTO )
private Long officeId;

@ManyToMany( mappedBy = "offices", targetEntity = Employee.class, fetch = FetchType.EAGER )
private List<Employee> employees = new ArrayList<Employee>();

我的联接表是:

    CREATE  TABLE IF NOT EXISTS `dental`.`EmployeeOfficeJoin` ( 
   `EmployeeId` BIGINT(11) ,
   `OfficeId` BIGINT(11),
   PRIMARY KEY ( `employeeId`, `officeId` ),
   FOREIGN KEY ( `employeeId` ) REFERENCES `Employee` (`EmployeeId` ),
   FOREIGN KEY ( `officeId` ) REFERENCES `Office` ( `Officeid` ) )
ENGINE = InnoDB

我正在使用此命名:

hibernate.ejb.naming_strategy=org.hibernate.cfg.DefaultNamingStrategy

当我尝试使用此:

Employee emp = new Employee();
...
emp.getOffices().add(newOffice);
employeeRepository.save(emp);

失败前的最后一个插入语句是:

Hibernate: 
    insert 
    into
        EmployeeOfficeJoin
        (EmployeeId, OfficeId) 
    values
        (?, ?)
TRACE - BasicBinder                - binding parameter [1] as [BIGINT] - 1
TRACE - BasicBinder                - binding parameter [2] as [BIGINT] - 1
DEBUG - SqlExceptionHelper         - Cannot add or update a child row: a foreign key constraint fails (`dental`.`employeeofficejoin`, CONSTRAINT `employeeofficejoin_ibfk_1` FOREIGN KEY (`EmployeeId`) REFERENCES `Employee` (`EmployeeId`)) [n/a]

看来情况已经改变了,我看到有人认为这可能是OS X上的MySQL问题。 但是当我使用

hibernate.ejb.naming_strategy=org.hibernate.cfg.ImprovedNamingStrategy

那对我来说并不能解决。

有人知道这是命名策略问题还是其他问题?

虽然我希望有一个不同的错误,但是JoinColumn中定义的字段似乎与您在关系表中指定为字段的内容不匹配。 尝试修复批注中的联接列以引用“ Employee_id”和“ Office_id”,而不是“ EmployeeId”和“ OfficeId”。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM