Hibernate 5 добавляет имя свойства в SQL-запрос - PullRequest
0 голосов
/ 11 октября 2018

Я перехожу с Hibernate 3 на Hibernate 5. Я столкнулся с проблемой следующих классов.Когда hibernate заполняет объект OrderStatus, он генерирует следующий SQL

    select
   fieldsacce0_.status_code as status_c1_78_0_,
   fieldsacce0_.fieldsAccess1_status_code as fieldsAc5_78_0_,
   fieldsacce0_.fieldsAccess1_field_code as fieldsAc6_78_0_,
   fieldsacce0_.field_code as field_co2_0_,
   agentsfiel1_.status_code as status_c1_78_1_,
   agentsfiel1_.field_code as field_co2_78_1_,
   agentsfiel1_.is_editable as is_edita3_78_1_,
   agentsfiel1_.is_visible as is_visib4_78_1_,
   agentfield2_.code as code1_77_2_,
   agentfield2_.name as name2_77_2_ 
from
   zusb_agent_fields_access fieldsacce0_ 
   inner join
      zusb_agent_fields agentfield2_ 
      on fieldsacce0_.field_code = agentfield2_.code 
   inner join
      zusb_agent_fields_access agentsfiel1_ 
      on fieldsacce0_.fieldsAccess1_status_code = agentsfiel1_.status_code 
      and fieldsacce0_.fieldsAccess1_field_code = agentsfiel1_.field_code 
where
   fieldsacce0_.status_code =?

Я не могу понять, почему Hibernate добавляет fieldsAccess1_?Я провел много времени, и видел такие экзамены, как it .Я не вижу разницы между примером и моим кодом.Надеюсь, у кого-нибудь есть идея.PS Извините за мой английский

      public class AgentFields implements Serializable {
private static final long serialVersionUID = 1929364703157730060L;

@Id
@Column(name = "code", length = 50)
private String code;

@NotNull
@Column(name = "name", columnDefinition = "nvarchar2(255)")
private String name;

public String getCode() {
    return code;
}

public void setCode(String code) {
    this.code = code;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}
}


@Entity
@Table(name="zusb_agent_fields_access")
@Embeddable
public class AgentsFieldAccess extends FieldAccess {
private static final long serialVersionUID = -198576118682083784L;
@Id
@Column(name = "status_code")
    private String statusCode;
@Id
    @Column(name = "field_code")
    private String fieldCode;

@Column(name = "is_visible", columnDefinition = "number(1, 0)")
private boolean visible;

@Column(name = "is_editable", columnDefinition = "number(1, 0)")
private boolean editable;
@Override
public boolean isVisible() {
    return visible;
}
@Override
public void setVisible(boolean visible) {
    this.visible = visible;
}
@Override
public boolean isEditable() {
    return editable;
}
@Override
public void setEditable(boolean editable) {
    this.editable = editable;
}
public String getStatusCode() {
    return statusCode;
}
public void setStatusCode(String statusCode) {
    this.statusCode = statusCode;
}
public String getFieldCode() {
    return fieldCode;
}
public void setFieldCode(String fieldCode) {
    this.fieldCode = fieldCode;
}


}


@Table( name = "zusb_agent_statuses") 
@Entity
public class OrderStatus  implements Serializable {
    @ElementCollection(targetClass = AgentsFieldAccess.class)
    @CollectionTable(name = "zusb_agent_fields_access", joinColumns = { @JoinColumn(name = "status_code", referencedColumnName = "code") })
    @MapKeyJoinColumn(name = "field_code")
    @Cache(usage = CacheConcurrencyStrategy.READ_WRITE)
    @Column(name = "fields_access")
    private Map<AgentFields, AgentsFieldAccess> fieldsAccess1 = new HashMap<AgentFields, AgentsFieldAccess>();
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...