`
ying_7839
  • 浏览: 14305 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

HQL子查询怎么会出错呢??

阅读更多
大家好!
现在做项目的时候,碰到了一个问题,请帮忙看看怎么会事吧,谢谢了先~~
1)映射文件:

<hibernate-mapping >
    <class name="Employee" table="EMPLOYEE">
       <composite-id name="Id" class="EmployeePK">
<key-property name="BusinessUnitId" column="BUSINESS_UNIT_ID" type="string" length="2" />
<key-property name="EmployeeId" column="EMPLOYEE_ID" type="string" length="10"/>
    </composite-id>
   <property
      name="FirstName"
      column="FIRST_NAME"
      type="string"
      length="40"
      not-null="true"
   />
   <property
      name="LastName"
      column="LAST_NAME"
      type="string"
      length="40"
      not-null="true"
   />
</class>
</hibernate-mapping>

2)代码:
  String s = "select x.FirstName,x.LastName from (select x.FirstName,x.LastName from Employee x)";
  List list = this.getSession().createQuery(s).list();

  当然了,那个子查询里面还有n多条件,为了方便大家找原因,我把条件去掉了。即使加上那些条件,还是一样的错误。
3)错误信息:

2006-11-20 19:52:09,100 DEBUG [org.hibernate.hql.ast.QueryTranslatorImpl] - parse() - HQL:  select x.FirstName,x.LastName from(  select x.FirstName,x.LastName from Employee x)
2006-11-20 19:52:09,100 ERROR [org.hibernate.hql.PARSER] - line 1:36: unexpected token: (
2006-11-20 19:52:09,100 DEBUG [org.hibernate.hql.ast.ErrorCounter] - line 1:36: unexpected token: (
line 1:36: unexpected token: (
at org.hibernate.hql.antlr.HqlBaseParser.fromRange(HqlBaseParser.java:1584)
at org.hibernate.hql.antlr.HqlBaseParser.fromClause(HqlBaseParser.java:1408)
at org.hibernate.hql.antlr.HqlBaseParser.selectFrom(HqlBaseParser.java:1130)
at org.hibernate.hql.antlr.HqlBaseParser.queryRule(HqlBaseParser.java:702)
at org.hibernate.hql.antlr.HqlBaseParser.selectStatement(HqlBaseParser.java:296)
at org.hibernate.hql.antlr.HqlBaseParser.statement(HqlBaseParser.java:159)
at org.hibernate.hql.ast.QueryTranslatorImpl.parse(QueryTranslatorImpl.java:248)
at org.hibernate.hql.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:157)
at org.hibernate.hql.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:111)
at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:77)
at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:56)
at org.hibernate.engine.query.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:72)
at org.hibernate.impl.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:133)
at org.hibernate.impl.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:112)
at org.hibernate.impl.SessionImpl.createQuery(SessionImpl.java:1623)
at com.pei.webpdm.itma.dao.hibernate.LabelImpl.getDivisionLabelList(LabelImpl.java:60)
at com.pei.webpdm.itma.dao.TestILabelDao.testgetDivisionLabelList(TestILabelDao.java:48)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at junit.framework.TestCase.runTest(TestCase.java:154)
at junit.framework.TestCase.runBare(TestCase.java:127)
at org.springframework.test.ConditionalTestCase.runBare(ConditionalTestCase.java:69)
at junit.framework.TestResult$1.protect(TestResult.java:106)
at junit.framework.TestResult.runProtected(TestResult.java:124)
at junit.framework.TestResult.run(TestResult.java:109)
at junit.framework.TestCase.run(TestCase.java:118)
at org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestReference.run(JUnit3TestReference.java:128)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:460)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:673)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:386)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196)
2006-11-20 19:52:09,100 ERROR [org.hibernate.hql.PARSER] - line 1:69: unexpected token: from
2006-11-20 19:52:09,100 DEBUG [org.hibernate.hql.ast.ErrorCounter] - line 1:69: unexpected token: from
line 1:69: unexpected token: from
at org.hibernate.hql.antlr.HqlBaseParser.fromClassOrOuterQueryPath(HqlBaseParser.java:1909)
at org.hibernate.hql.antlr.HqlBaseParser.fromRange(HqlBaseParser.java:1564)
at org.hibernate.hql.antlr.HqlBaseParser.fromClause(HqlBaseParser.java:1428)
at org.hibernate.hql.antlr.HqlBaseParser.selectFrom(HqlBaseParser.java:1130)
at org.hibernate.hql.antlr.HqlBaseParser.queryRule(HqlBaseParser.java:702)
at org.hibernate.hql.antlr.HqlBaseParser.selectStatement(HqlBaseParser.java:296)
at org.hibernate.hql.antlr.HqlBaseParser.statement(HqlBaseParser.java:159)
at org.hibernate.hql.ast.QueryTranslatorImpl.parse(QueryTranslatorImpl.java:248)
at org.hibernate.hql.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:157)
at org.hibernate.hql.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:111)
at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:77)
at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:56)
at org.hibernate.engine.query.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:72)
at org.hibernate.impl.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:133)
at org.hibernate.impl.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:112)
at org.hibernate.impl.SessionImpl.createQuery(SessionImpl.java:1623)
at com.pei.webpdm.itma.dao.hibernate.LabelImpl.getDivisionLabelList(LabelImpl.java:60)
at com.pei.webpdm.itma.dao.TestILabelDao.testgetDivisionLabelList(TestILabelDao.java:48)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:585)
at junit.framework.TestCase.runTest(TestCase.java:154)
at junit.framework.TestCase.runBare(TestCase.java:127)
at org.springframework.test.ConditionalTestCase.runBare(ConditionalTestCase.java:69)
at junit.framework.TestResult$1.protect(TestResult.java:106)
at junit.framework.TestResult.runProtected(TestResult.java:124)
at junit.framework.TestResult.run(TestResult.java:109)
at junit.framework.TestCase.run(TestCase.java:118)
at org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestReference.run(JUnit3TestReference.java:128)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:460)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:673)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:386)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196)
2006-11-20 19:52:09,116 DEBUG [org.hibernate.hql.ast.AST] - --- HQL AST ---
\-[QUERY] 'query'
    \-[SELECT_FROM] 'SELECT_FROM'
       +-[FROM] 'from'
       \-[SELECT] 'select'
          +-[DOT] '.'
          |  +-[IDENT] 'x'
          |  \-[IDENT] 'FirstName'
          \-[DOT] '.'
             +-[IDENT] 'x'
             \-[IDENT] 'LastName'
分享到:
评论
7 楼 ying_7839 2006-11-21  
知道了,是Hibernate本身不支持在from后的子查询的,只支持where子句后的子查询。
这下可比较郁闷了...
6 楼 ying_7839 2006-11-21  
那个的确是不正确的,我分别试了x.*;*;firstName、lastName;FirstName、LastName;....几乎可能的值都试过了,可是还是不对呢。
真不知道类似这样的HQL该怎么写了。
5 楼 wuyunlong 2006-11-20  
引用
select x.FirstName,x.LastName from (select x.FirstName,x.LastName from Employee x)


在上面的查询语句中x的有效范围应该是
引用
(select x.FirstName,x.LastName from Employee x)

在括号之外,x应该是无效的!
4 楼 ying_7839 2006-11-20  
抛出异常的爱 写道

SQL文写错了

写错了,问题是不知道错在那里了。如果知道的话,提醒一声吧。
这个已经是最简单的东西了吧?实在不知道再从那里开始试起。

自己的感觉应该是前半部门有问题,可是如果从一个查询结果中取一个子集,那个sql文该如何写呢?
3 楼 ying_7839 2006-11-20  
daoger 写道
没见过那么怪的查询语句!没有查询条件吗?

呵呵,不是没有查询条件,只是为了方便,将相关的条件隐去了。
情况是这样的,这是一个子查询的一部分

select x.FirstName,x.LastName from Employee x
实际上后面是一个group by分组查询,在结果中取到FirstName之后,再让FirstName作为令外的条件再进行查询。举个例子,比如查询一个部门内姓李的员工的考勤信息。
所有我需要select x.FirstName from(Select x.FirstName,x.LastName from Employee x group by x.FirstName,x.LastName having ...(略去)) where 各种条件。

我把所有的条件都去掉,发现这里select x.FirstName,x.LastName from(开始出错,所以我只贴了这部分的代码。

PS:非常感谢你的关注,如果发现什么问题了,情及时回复哦。谢谢了先。
2 楼 抛出异常的爱 2006-11-20  

SQL文写错了
从简单的东西试起
1 楼 daoger 2006-11-20  
没见过那么怪的查询语句!没有查询条件吗?

相关推荐

    HQL详解

    HQL也支持子查询,可以嵌套在`SELECT`, `FROM`, `WHERE`等子句中。 ```sql SELECT p FROM Person p WHERE p.age IN (SELECT AVG(a.age) FROM AgeGroup a) ``` 这个查询会找出年龄在平均年龄之上的所有人。 ### ...

    hirbernate2

    5. **Criteria API的子查询**:在高级查询中,可能会用到Criteria API的子查询功能,这使得在Java代码中嵌套查询变得更加方便。 6. **一对多和多对一关系映射**:理解如何配置和使用实体间的一对多和多对一关系,...

    hibernate资料

    为了提升性能,开发者需要注意一些最佳实践,如合理使用缓存、避免过多的HQL子查询、批处理操作(Batch Processing)、预加载关联对象(Eager Fetching)等。 综上所述,Hibernate是一个强大的ORM工具,通过深入...

    hibernate中文参考文档

    它可以进行复杂的条件查询、分组、排序等操作,并支持子查询。 七、Criteria查询 Criteria API提供了一种更加面向对象的查询方式,通过构建Criteria对象来执行查询,更易读且不易出错。 八、缓存机制 Hibernate...

    Hibernate开发指南

    8. **其他高级特性**:包括级联操作、事件监听、动态模型、子查询、联合查询、自定义类型等。 9. **实战案例**:通过实际项目案例,展示如何在Web应用(如Spring Boot)中集成Hibernate,以及如何解决实际开发中...

    hibernate api

    HQL支持复杂的查询,如联接、子查询和集合操作,使开发者能以更直观的方式操作对象。 5. **Entity和持久化类** 在Hibernate中,实体代表数据库表,持久化类是这些实体的Java表示。通过在类上使用@Entity注解,我们...

    hibernate3.2中文参考手册

    HQL支持复杂的查询,如联接、子查询和聚合函数。同时,Criteria API提供了一种更加面向对象的查询方式,无需编写字符串查询,降低了出错的可能性。 六、缓存机制 为了提高性能,Hibernate支持多种级别的缓存:第一...

    hibernate-原理共2页.pdf.zip

    它支持聚合函数、子查询、连接查询等。 2. **Criteria API**:提供一种面向对象的方式来构建查询,无需编写字符串查询语句,更加安全,不易出错。 **四、缓存机制** Hibernate提供了两级缓存:第一级缓存是...

    hibernate:java持久化对象详解02

    在“hibernate:java持久化对象详解02”中,你可能会接触到更复杂的查询技巧,如联接查询、子查询、分页查询等,以及如何使用 Criteria API 来实现这些查询。同时,可能会讲解到级联操作(Cascade)、懒加载(Lazy ...

    Hibernate学习PPT

    8. **Criteria查询**:提供了一种基于对象的查询方式,比HQL更加灵活,不需要预先编写查询字符串。 9. ** Criteria API**:是Hibernate提供的另一种查询API,允许动态构建查询条件,适用于需要动态生成查询的情况。...

    Check-SQ

    9. **SQL查询设计**:如何编写高效的SELECT语句,使用GROUP BY、HAVING、UNION等操作,以及何时使用子查询和联接,都是优化查询的关键。 10. **错误处理和异常处理**:在Java中,当SQL执行出错时,会抛出...

    hibernate

    在JDBC中,开发人员经常遇到大量代码重复、绑定到特定数据库、易出错的try/catch/finally块、难以处理的关系(如N+1选择问题和父/子更新)等问题。这些问题导致了开发效率低下和代码维护困难。为了解决这些问题,...

Global site tag (gtag.js) - Google Analytics