本文介绍了本机SQL引发无效的列名称异常的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述



我有一个 Dept 表和一个 Employees 表。



Dept.java

  private int deptId; 
private String deptName;
私人地图empMap = new HashMap();
// Getters and Setters

Employees.java

  private int empId; 
private String empName;
private int deptId;
private int age;
私人字符串性别;
私营部门部门;

HBM映射文件

 < class name =com.jdbc.Depttable =dept> 
< id name =deptIdtype =integercolumn =DEPT_ID>
< generator class =assigned>< / generator>
< / id>
< property name =deptName>
< column name =DEPT_NAME>< / column>
< / property>
< key column =DEPT_ID>< / key>
< / map>


下面是Native SQL:

  SQLQuery query = session.createSQLQuery(从d部分选择d.DEPT_ID,e.EMP_NAME,Emp e其中d .DEPT_ID = e.DEPT_ID)
.addEntity(Dept.class);
列表< Dept> departments = query.list();
(部门出发部门)
System.out.println(depart.getDeptName());

我收到异常:

 org.hibernate.exception.GenericJDBCException:无法在org.hibernate.exception.SQLStateConverter.handledNonSpecificException(SQLStateConverter.java:103)上执行查询
$ or $ $ $ b $ org.hibernate .aception.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)
在org.hibernate.loader.custom.CustomLoader.list(CustomLoader.java:289)
在org.hibernate.impl.SessionImpl.listCustomQuery(SessionImpl.java:1695)
在org.hibernate。 impl.AbstractSessionImpl.list(AbstractSessionImpl.java:142)
在org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:152)
在com.jdbc.HibernateStartup.main(HibernateStartup.java: 75)
导致:java.sql.SQLException:无效的列名称
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)
在org.hibernate.type.NullableType.nullSafeGet(NullableType.java:163)
在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 )在org.hibernate.loader.Loader.loadFromRe上
sultSet(Loader.java:1380)
在org.hibernate.loader.Loader.instanceNotYetLoaded(Loader.java:1308)
在org.hibernate.loader.Loader.getRow(Loader.java:1206)
在org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:580)
在org.hibernate.loader.Loader.doQuery(Loader.java:701)
在org.hibernate .loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:236)
at org.hibernate.loader.Loader.doList(Loader.java:2220)
... 7 more

当我直接在db中运行查询时,我得到正确的输出,但是在hibernate中,它给出了一个无效的COlumn名称。我已经确认列名是正确的。



请让我知道如何解决此问题。


$ b

 < column name =DEPT_NAME>解决方案

>< /列>

但是在> Select session.createSQLQuery(Select d .DEPT_ID,e.EMP_NAME from Dept d,Emp e where d.DEPT_ID = e.DEPT_ID)

Hibernate没有可能绑定属性。
试试这个:

  session.createSQLQuery(选择d.DEPT_ID,d.DEPT_NAME,e.EMP_NAME来自Dept d,Emp e where d.DEPT_ID = e.DEPT_ID)


I am using Hibernate 3.2.5 for my application.

I have a Dept table and an Employees table.

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 Mapping file

<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>

Below is the code for 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());

I am getting the exception:

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

When I run the query directly in the db, then I am getting the correct output but in hibernate, it is giving an Invalid COlumn name. I have confirmed that the column names are correct only.

Kindly let me know how to fix this issue.

解决方案

you have this in your mapping:

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

but there is no such column in your sql between Select and from:

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

Hibernate has no possibilitys to bind the attribute.Try it with this:

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

这篇关于本机SQL引发无效的列名称异常的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

07-22 12:07