【问题标题】:Native SQL throwing Invalid Column Name Exception本机 SQL 抛出 Invalid Column Name 异常
【发布时间】:2013-06-23 16:18:18
【问题描述】:

我正在为我的应用程序使用 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 映射文件

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

下面是 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());

我遇到了异常:

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。我已经确认列名是正确的。

请告诉我如何解决此问题。

【问题讨论】:

  • Employees 类的映射在哪里?
  • 您的查询丢失DEPT_NAME
  • 为什么会有这种行为?如果它是一个有很多列的大表,我需要一些列来满足我的目的怎么办?在那种情况下,我还必须添加所有列名?请解释一下。

标签: java hibernate orm hibernate-mapping


【解决方案1】:

你的映射中有这个:

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

但是在Selectfrom 之间的sql 中没有这样的列:

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

【讨论】:

  • 为什么会有这种行为?如果它是一个有很多列的大表,我需要一些列来满足我的目的怎么办?在那种情况下,我还必须添加所有列名?请解释一下。
  • 在这种情况下,您可以使用“select * from”
  • 如果我需要其中的一些而不是全部怎么办?是原生 SQL 优于 HQL 还是标准?
  • 我有一个大表的问题,我只需要一些数据。我不能使用 * 或 d.* ,因为这会请求过多的数据并减慢它的速度。我该怎么办?这里没有 HQL 和 Criteria 选项。
【解决方案2】:

我遇到了同样的问题。

原因是我注释中的列名不正确。

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

应该改为

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

【讨论】:

    【解决方案3】:

    这是我的 2cents 以及 Stefan Beike 的东西。

    在您的情况下,桌子很小。但是,如果您正在为大型表编写类似的查询,并且您不希望将整个列提取到内存中,那么编写一个新的 DataTransferObject 用作​​您的结果集引用将是理想的。

    【讨论】:

      猜你喜欢
      • 2012-03-03
      • 1970-01-01
      • 2019-11-20
      • 2018-12-29
      • 2014-12-24
      • 2021-12-20
      • 1970-01-01
      • 1970-01-01
      • 2014-12-10
      相关资源
      最近更新 更多