Mam encję z osadzonym kluczem. Jednostka ma tylko klucz jako pole, a klucz ma 7 pól, z których niektóre mogą mieć wartość zerową.Lista pusta zwrócona z zapytania hibernacji z osadzonym identyfikatorem
Kiedy uruchomić następujące zapytanie:
Criteria criteria = session.createCriteria(getPersistentClass());
criteria.add(Restrictions.eq("id.profPropertyId", profileExtensionName));
Object obj = criteria.list();
log.info(obj);
return (List<ProfileExtensions>) obj;
uzyskać odpowiednią liczbę wyników, ale każdy wynik jest zerowy (czyli uzyskać listę obiektów zerowych 4000). Próbowałem używać zarówno kwerendy HQL i kryteria, ale oba dają ten sam wynik.
Klasy odwzorowań zostały wygenerowane z istniejącej bazy danych.
SQL generowane dla zapytania jest następujący
select this_.PROF_DATA_TYPE as PROF1_14_0_, this_.PROF_EXT_KEY as PROF2_14_0_,
this_.PROF_KEY as PROF3_14_0_, this_.PROF_NAME as PROF4_14_0_,
this_.PROF_PROPERTY_ID as PROF5_14_0_, this_.PROF_VALUE as PROF6_14_0_,
this_.PROF_VALUE_EXTENDED as PROF7_14_0_
from EMPINST.PROFILE_EXTENSIONS this_
where this_.PROF_PROPERTY_ID=?
Wygląda powinien wrócić poprawne dane.
plik odwzorowania jest bardzo proste (i generowany ze schematu.
// Generated Oct 18, 2010 11:08:08 PM by Hibernate Tools 3.2.2.GA
import javax.persistence.AttributeOverride;
import javax.persistence.AttributeOverrides;
import javax.persistence.Column;
import javax.persistence.EmbeddedId;
import javax.persistence.Entity;
import javax.persistence.Table;
import javax.persistence.UniqueConstraint;
@Entity
@Table(name="PROFILE_EXTENSIONS"
,schema="EMPINST"
, uniqueConstraints = @UniqueConstraint(columnNames={"PROF_KEY", "PROF_PROPERTY_ID"}))
public class ProfileExtensions implements java.io.Serializable {
private ProfileExtensionsId id;
public ProfileExtensions() {
}
public ProfileExtensions(ProfileExtensionsId id) {
this.id = id;
}
@EmbeddedId
@AttributeOverrides({
@AttributeOverride(name="profKey", [email protected](name="PROF_KEY", nullable=false, length=36)),
@AttributeOverride(name="profPropertyId", [email protected](name="PROF_PROPERTY_ID", nullable=false, length=64)),
@AttributeOverride(name="profExtKey", [email protected](name="PROF_EXT_KEY", length=256)),
@AttributeOverride(name="profName", [email protected](name="PROF_NAME", length=256)),
@AttributeOverride(name="profDataType", [email protected](name="PROF_DATA_TYPE", length=64)),
@AttributeOverride(name="profValue", [email protected](name="PROF_VALUE", length=1024)),
@AttributeOverride(name="profValueExtended", [email protected](name="PROF_VALUE_EXTENDED")) })
public ProfileExtensionsId getId() {
return this.id;
}
public void setId(ProfileExtensionsId id) {
this.id = id;
}
}
Jaki kod SQL jest generowany? Pokaż również swoje mapowanie i tabelę (w miarę możliwości). –