FetchMode работает только со столбцом первичного ключа

Я изменил код, но проблема все еще существует

    CandidateResumeInfo candidateResumeInfo = new CandidateResumeInfo();
    ArrayList<CandidateResumeInfo> allCandidateResumeInfo= new ArrayList<CandidateResumeInfo>();

    Session session = sessionFactory.openSession();
    String city1 ="Anniston";

    Criteria  crit = session.createCriteria(CandidateResumeInfo.class);
    crit.createAlias("candidate", "candidateinfo");

    //crit.setFetchMode("candidateinfo", FetchMode.JOIN);
    crit.add( Restrictions.eq("candidateinfo.city", city1));
    List list = crit.list();

вот класс сущности.. открытый класс CandidateResumeInfo реализует Serializable{...

      @OneToMany     
      CandidateInfo candidate;

      ....
      }
      public class CandidateInfo implements Serializable{
      .......

     @Column(name="city")
     private String city;
      .......
      }

Вот несколько верхних строк трассировки стека. Это некоторый RPC.class (он появляется в этой строке, в которой говорится, что Throwable причина = e.getCause(); и справа от переменных (в режиме отладки) написано java.lang.reflect .InvocationTargetException , но в трассировке стека нет ничего java.lang.reflect.InvocationTargetException

   public final class RPC {
    .......
   public static String invokeAndEncodeResponse(Object target,
  Method serviceMethod, Object[] args,
  SerializationPolicy serializationPolicy, int flags)
  throws SerializationException {
if (serviceMethod == null) {
  throw new NullPointerException("serviceMethod");
}

if (serializationPolicy == null) {
  throw new NullPointerException("serializationPolicy");
}

String responsePayload;
try {
  Object result = serviceMethod.invoke(target, args);

  responsePayload = encodeResponseForSuccess(serviceMethod, result,
      serializationPolicy, flags);
} catch (IllegalAccessException e) {
  SecurityException securityException = new SecurityException(
      formatIllegalAccessErrorMessage(target, serviceMethod));
  securityException.initCause(e);
  throw securityException;
} catch (IllegalArgumentException e) {
  SecurityException securityException = new SecurityException(
      formatIllegalArgumentErrorMessage(target, serviceMethod, args));
  securityException.initCause(e);
  throw securityException;
} catch (InvocationTargetException e) {
  // Try to encode the caught exception
  //
  **Throwable cause = e.getCause();**   // THIS IS THE LINE WHERE IT BRINGS ME ..

  responsePayload = encodeResponseForFailure(serviceMethod, cause,
      serializationPolicy, flags);
}

person junaidp    schedule 30.05.2011    source источник


Ответы (1)


crit.createAlias("Class2", "c2").add(Restrictions.eq("c2.zip", 123)

должен сделать это...

Если вы просто используете «zip», hibernate будет искать свойство zip в классе Class1; это не имеет ничего общего с тем, является ли свойство PK или нет.

person Stijn Geukens    schedule 30.05.2011
comment
Спасибо, я изменил код, как вы сказали, все еще не решен, пожалуйста, просмотрите приведенный выше код (я вставил фактический код) и дайте мне знать, если я делаю что-то неправильно, спасибо - person junaidp; 30.05.2011
comment
crit.createAlias("CandidateInfo" ...); если ваш объект называется кандидатом, это должно быть crit.createAlias("candidate", ... - person Stijn Geukens; 30.05.2011
comment
изменил его, также отредактировал выше, проблема все еще существует, любое предложение. Мне нужно что-то сделать в другом месте, чтобы сделать ПРИСОЕДИНЕНИЕ. Благодарность - person junaidp; 30.05.2011
comment
С какой именно проблемой вы столкнулись; у вас есть исключение? - person Stijn Geukens; 30.05.2011
comment
в приведенной выше строке List list = crit.list(); это исключение java.lang.reflect.InvocationTargetException, но если я использую кандидатинфо.ид вместо кандидатинфо.город, он работает нормально (поскольку идентификатор является первичным ключом), но я хочу связать город, а не идентификатор, хочу установить некоторые критерии для города в классе csndidateinfo. Благодарность - person junaidp; 30.05.2011
comment
Hibernate автоматически присоединится к идентификатору, теперь это можно обойти, но это нормально. Вам нужно присоединиться по идентификатору, а затем отфильтровать по городу. Ваш запрос работает без createAlias ​​и ограничений? Добавьте полную трассировку стека к своему вопросу. - person Stijn Geukens; 30.05.2011
comment
да, он работает без createAlias ​​и ограничений. Я пытался вставить сюда полный трек, но он пишет, что превышен лимит текста - person junaidp; 30.05.2011
comment
@junaidp, см. benpryor.com/blog/2006 /08/15/ если поможет. Для трассировки стека вы можете попробовать поместить несколько верхних строк. - person Reddy; 30.05.2011
comment
спасибо, сайт не помог, я прикрепил трассировку стека выше, не думаю, что это будет полезно. если хотите, я могу отправить вам полный текст - person junaidp; 31.05.2011
comment
Это не трассировка стека, а просто часть журнала; нам нужна часть, начинающаяся с java.lang.reflect.InvocationTargetException и вызванная 's. - person Stijn Geukens; 31.05.2011
comment
Это код, а не трассировка стека. Это трассировка стека - person Stijn Geukens; 31.05.2011