大家好!
现在做项目的时候,碰到了一个问题,请帮忙看看怎么会事吧,谢谢了先~~
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'
分享到:
相关推荐
HQL也支持子查询,可以嵌套在`SELECT`, `FROM`, `WHERE`等子句中。 ```sql SELECT p FROM Person p WHERE p.age IN (SELECT AVG(a.age) FROM AgeGroup a) ``` 这个查询会找出年龄在平均年龄之上的所有人。 ### ...
5. **Criteria API的子查询**:在高级查询中,可能会用到Criteria API的子查询功能,这使得在Java代码中嵌套查询变得更加方便。 6. **一对多和多对一关系映射**:理解如何配置和使用实体间的一对多和多对一关系,...
为了提升性能,开发者需要注意一些最佳实践,如合理使用缓存、避免过多的HQL子查询、批处理操作(Batch Processing)、预加载关联对象(Eager Fetching)等。 综上所述,Hibernate是一个强大的ORM工具,通过深入...
它可以进行复杂的条件查询、分组、排序等操作,并支持子查询。 七、Criteria查询 Criteria API提供了一种更加面向对象的查询方式,通过构建Criteria对象来执行查询,更易读且不易出错。 八、缓存机制 Hibernate...
8. **其他高级特性**:包括级联操作、事件监听、动态模型、子查询、联合查询、自定义类型等。 9. **实战案例**:通过实际项目案例,展示如何在Web应用(如Spring Boot)中集成Hibernate,以及如何解决实际开发中...
HQL支持复杂的查询,如联接、子查询和集合操作,使开发者能以更直观的方式操作对象。 5. **Entity和持久化类** 在Hibernate中,实体代表数据库表,持久化类是这些实体的Java表示。通过在类上使用@Entity注解,我们...
HQL支持复杂的查询,如联接、子查询和聚合函数。同时,Criteria API提供了一种更加面向对象的查询方式,无需编写字符串查询,降低了出错的可能性。 六、缓存机制 为了提高性能,Hibernate支持多种级别的缓存:第一...
它支持聚合函数、子查询、连接查询等。 2. **Criteria API**:提供一种面向对象的方式来构建查询,无需编写字符串查询语句,更加安全,不易出错。 **四、缓存机制** Hibernate提供了两级缓存:第一级缓存是...
在“hibernate:java持久化对象详解02”中,你可能会接触到更复杂的查询技巧,如联接查询、子查询、分页查询等,以及如何使用 Criteria API 来实现这些查询。同时,可能会讲解到级联操作(Cascade)、懒加载(Lazy ...
8. **Criteria查询**:提供了一种基于对象的查询方式,比HQL更加灵活,不需要预先编写查询字符串。 9. ** Criteria API**:是Hibernate提供的另一种查询API,允许动态构建查询条件,适用于需要动态生成查询的情况。...
9. **SQL查询设计**:如何编写高效的SELECT语句,使用GROUP BY、HAVING、UNION等操作,以及何时使用子查询和联接,都是优化查询的关键。 10. **错误处理和异常处理**:在Java中,当SQL执行出错时,会抛出...
在JDBC中,开发人员经常遇到大量代码重复、绑定到特定数据库、易出错的try/catch/finally块、难以处理的关系(如N+1选择问题和父/子更新)等问题。这些问题导致了开发效率低下和代码维护困难。为了解决这些问题,...