2013-06-26 15 views
7

Używam Hibernate 3.2.5 dla mojej aplikacji.Natywny wyrzucanie SQL Niepoprawna nazwa kolumny Wyjątek

Mam tabelę Dept i tabelę .

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; 

plik mapowania HBM

<class name="com.jdbc.Dept" table="dept"> 
    <id name="deptId" type="integer" column="DEPT_ID"> 
     <generator class="assigned"></generator> 
    </id> 
    <property name="deptName"> 
     <column name="DEPT_NAME"></column> 
    </property>  
    <map name="empMap" inverse="false" cascade="all" lazy="true"> 
     <key column="DEPT_ID"></key> 
     <map-key formula="EMP_ID" type="integer"></map-key> 
     <one-to-many class="com.jdbc.Employees"/> 
    </map> 

Poniżej znajduje się kod dla Native 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<Dept> departments = query.list(); 
     for(Dept depart :departments) 
      System.out.println(depart.getDeptName()); 

otrzymuję wyjątek:

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 

Kiedy uruchomić kwerendę bezpośrednio w db, następnie otrzymuję poprawny wynik ale w stanie hibernacji daje to Invalid COlumn name. Potwierdziłem, że nazwy kolumn są poprawne.

Prosimy o informację, jak rozwiązać ten problem.

+0

A gdzie jest twój mapowanie dla klasy 'Employees'? – Andremoniy

+1

W zapytaniu brakuje "DEPT_NAME" –

+0

Dlaczego takie zachowanie? Co jeśli jest to duży stół z mnóstwem kolumn, w których potrzebuję niektórych kolumn do mojego celu? W takim przypadku muszę też dodać wszystkie nazwy kolumn? Uprzejmie wyjaśnij. – user182944

Odpowiedz

8

masz to w swoim mapowania:

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

ale nie ma takiej kolumny w sql między Select i from:

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

Hibernate ma possibilitys do wiążą atrybut. Spróbuj tego:

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

Dlaczego takie zachowanie? Co jeśli jest to duży stół z mnóstwem kolumn, w których potrzebuję niektórych kolumn do mojego celu? W takim przypadku muszę też dodać wszystkie nazwy kolumn? Uprzejmie wyjaśnij. – user182944

+1

W takim przypadku możesz użyć "wybierz * z" –

+1

Co, jeśli potrzebuję niektórych z nich, a nie wszystkich? Czy nie jest to Native SQL w porównaniu z HQL lub kryteriami? – user182944

1

Miałem ten sam problem.

Powód jest moja nazwa kolumny w adnotacji nie jest poprawne.

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

należy zmienić

@Column(name = "CUST_NM", length = 200) 
Powiązane problemy