Собственный SQL, выбрасывающий недопустимое исключение имени столбца

Я использую Hibernate 3.2.5 для своего приложения.

у меня естьDept стол иEmployees Таблица.

Dept.java

private int deptId;
private String deptName;
private Map empMap = new HashMap();
//Getters and Setters

Employees.java

private int empId;
private String empName;
private int deptId;
private int age;
private String sex;
private Dept dept;

Картографический файл HBM


  
      
    
  
      
      
  
      
      
      
  

Ниже приведен код для собственного SQL:

SQLQuery query = session.createSQLQuery("Select d.DEPT_ID, e.EMP_NAME from Dept d,Emp e where d.DEPT_ID = e.DEPT_ID")
                .addEntity(Dept.class);
List departments = query.list();
        for(Dept depart :departments)
            System.out.println(depart.getDeptName());

Я получаю исключение:

org.hibernate.exception.GenericJDBCException: could not execute query
at org.hibernate.exception.SQLStateConverter.handledNonSpecificException(SQLStateConverter.java:103)
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:91)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
at org.hibernate.loader.Loader.doList(Loader.java:2223)
at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2104)
at org.hibernate.loader.Loader.list(Loader.java:2099)
at org.hibernate.loader.custom.CustomLoader.list(CustomLoader.java:289)
at org.hibernate.impl.SessionImpl.listCustomQuery(SessionImpl.java:1695)
at org.hibernate.impl.AbstractSessionImpl.list(AbstractSessionImpl.java:142)
at org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:152)
at com.jdbc.HibernateStartup.main(HibernateStartup.java:75)
Caused by: java.sql.SQLException: Invalid column name
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:111)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:145)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:207)
at oracle.jdbc.driver.OracleStatement.getColumnIndex(OracleStatement.java:3295)
at oracle.jdbc.driver.OracleResultSetImpl.findColumn(OracleResultSetImpl.java:1913)
at oracle.jdbc.driver.OracleResultSet.getString(OracleResultSet.java:1514)
at org.hibernate.type.StringType.get(StringType.java:18)
at org.hibernate.type.NullableType.nullSafeGet(NullableType.java:163)
at org.hibernate.type.NullableType.nullSafeGet(NullableType.java:154)
at org.hibernate.type.AbstractType.hydrate(AbstractType.java:81)
at org.hibernate.persister.entity.AbstractEntityPersister.hydrate(AbstractEntityPersister.java:2096)
at org.hibernate.loader.Loader.loadFromResultSet(Loader.java:1380)
at org.hibernate.loader.Loader.instanceNotYetLoaded(Loader.java:1308)
at org.hibernate.loader.Loader.getRow(Loader.java:1206)
at org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:580)
at org.hibernate.loader.Loader.doQuery(Loader.java:701)
at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:236)
at org.hibernate.loader.Loader.doList(Loader.java:2220)
... 7 more

Когда я запускаю запрос непосредственно в БД, то получаю правильный вывод, но в спящем режиме он даетInvalid COlumn name, Я подтвердил, что имена столбцов являются правильными.

Пожалуйста, дайте мне знать, как решить эту проблему.

 Andremoniy26 июн. 2013 г., 15:40
И где ваше отображение дляEmployees учебный класс?
 Mark Rotteveel26 июн. 2013 г., 15:44
Ваш запрос отсутствуетDEPT_NAME
 user18294426 июн. 2013 г., 16:26
Почему такого рода поведение? Что делать, если это большая таблица с большим количеством столбцов, для которой мне нужны некоторые столбцы? В этом случае также я должен добавить все имена столбцов? Пожалуйста, объясните.

Ответы на вопрос(2)

Причина в том, что название моей колонки в аннотации неверно.

@Column(name = "CUSTOMER_NAME", length = 200)

следует изменить на

@Column(name = "CUST_NM", length = 200)
Решение Вопроса

<column name="DEPT_NAME"></column>

но нет такого столбца в вашем sql междуSelect а также :from

session.createSQLQuery("Select d.DEPT_ID, e.EMP_NAME from Dept d,Emp e where d.DEPT_ID = e.DEPT_ID")

Hibernate не имеет возможности связать атрибут. Попробуйте это с этим:

session.createSQLQuery("Select d.DEPT_ID, d.DEPT_NAME, e.EMP_NAME from Dept d,Emp e where d.DEPT_ID = e.DEPT_ID")
 user18294426 июн. 2013 г., 16:29
Что если мне понадобятся некоторые из них, а не все? Это несоответствие Native SQL над HQL или критериев? "
 Stefan Beike26 июн. 2013 г., 16:32
Выберите d. *, E.EMP_NAME из " Я не знаком с критериями ...
 Stefan Beike26 июн. 2013 г., 16:27
В этом случае вы можете использоватьвыбрать из"
 user18294426 июн. 2013 г., 16:26
Почему такого рода поведение? Что делать, если это большая таблица с большим количеством столбцов, для которой мне нужны некоторые столбцы? В этом случае также я должен добавить все имена столбцов? Пожалуйста, объясните.
 T3rm112 февр. 2014 г., 11:43
У меня эта проблема с огромной таблицей, где мне нужны только некоторые данные. Я не могу использовать * или d. *, Потому что это будет запрашивать слишком много данных и слишком сильно их замедлять. Что я должен делать? HQL и критерии здесь не вариант.

Ваш ответ на вопрос