2014-11-21 41 views
0

我被困在一個查詢,我試圖從SQL轉換到JPQL。首先是兩個SQL查詢運行良好,最後是我的失敗查詢以及錯誤:意外的AST節點左外部連接

//SUCCEEDS-----! 
//select * from defermentaccount LEFT OUTER JOIN division ON defermentaccount.deferment_ID=division.divisionID; 
//select * from defermentaccount d LEFT OUTER JOIN division v ON d.deferment_ID=v.divisionID; 
//FAILS--------!  
Query q1 = em.createQuery("SELECT defm FROM DefermentAccount defm LEFT JOIN defm.division division ON division.divisionID=:defm.defermentID"); 

任何幫助非常感謝!

STACK:

java.lang.IllegalArgumentException: org.hibernate.hql.internal.ast.QuerySyntaxException: unexpected AST node: : near line 1, column 129 [SELECT defm FROM uk.co.ash.Server.domain.DefermentAccount defm LEFT JOIN defm.division division ON (division.divisionID=:defm.defermentID)] 
at org.hibernate.jpa.spi.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1750) 
at org.hibernate.jpa.spi.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1677) 
at org.hibernate.jpa.spi.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1683) 
at org.hibernate.jpa.spi.AbstractEntityManagerImpl.createQuery(AbstractEntityManagerImpl.java:331) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at org.springframework.orm.jpa.ExtendedEntityManagerCreator$ExtendedEntityManagerInvocationHandler.invoke(ExtendedEntityManagerCreator.java:342) 
at com.sun.proxy.$Proxy33.createQuery(Unknown Source) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at org.springframework.orm.jpa.SharedEntityManagerCreator$SharedEntityManagerInvocationHandler.invoke(SharedEntityManagerCreator.java:289) 
at com.sun.proxy.$Proxy33.createQuery(Unknown Source) 
at uk.co.ash.dao.JPQLJUnitTest.stage1_pull_back_all_users(JPQLJUnitTest.java:65) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47) 
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44) 
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:72) 
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:81) 
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:72) 
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271) 
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:216) 
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:82) 
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238) 
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63) 
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236) 
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53) 
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229) 
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:60) 
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:67) 
at org.junit.runners.ParentRunner.run(ParentRunner.java:309) 
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:162) 
at org.junit.runner.JUnitCore.run(JUnitCore.java:160) 
at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:67) 

----以下是錯誤 - 這樣堅持,我給一些更詳細...

Caused by: org.hibernate.hql.internal.ast.QuerySyntaxException: unexpected AST node: : near line 1, column 129 [SELECT defm FROM uk.co.ash.Server.domain.DefermentAccount defm LEFT JOIN defm.division division ON (division.divisionID=:defm.defermentID)] 
at org.hibernate.hql.internal.ast.QuerySyntaxException.convert(QuerySyntaxException.java:91) 
at org.hibernate.hql.internal.ast.ErrorCounter.throwQueryException(ErrorCounter.java:109) 
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:284) 
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:206) 
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:158) 
at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:131) 
at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:93) 
at org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:167) 
at org.hibernate.internal.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:301) 
at org.hibernate.internal.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:236) 
at org.hibernate.internal.SessionImpl.createQuery(SessionImpl.java:1800) 
at org.hibernate.jpa.spi.AbstractEntityManagerImpl.createQuery(AbstractEntityManagerImpl.java:328) 
... 40 more 

謝謝!

+0

感謝您的幫助,但我認爲這就是我已經... ...? Query q1 = em.createQuery(「SELECT defm FROM DefermentAccount defm LEFT JOIN defm.division division ON division.divisionID =:defm.defermentID」); ------ org.hibernate.hql.internal.ast.QuerySyntaxException:unexpected AST節點:在第1行附近, – 2014-11-21 16:31:26

+0

「defm」實際上是列名嗎?你已經使它成爲一個表別名。 – 2014-11-21 16:32:39

+0

沒有定義列,但也不是延遲帳戶列。 DDL - ( deferment_ID BIGINT PRIMARY KEY NOT NULL AUTO_INCREMENT, deferment_Account_End_Date DATETIME, deferment_Account_Max_Balance DECIMAL(12,2), deferment_Account_Notes VARCHAR(255), deferment_Account_Number VARCHAR(255), deferment_Account_Start_Date DATETIME, division_Deferment_Join_Column BIGINT, FOREIGN KEY(division_Deferment_Join_Column)REFERENCES部門(divisionID) ); CREATE INDEX FK_lc3jh0hjn8mbrhqqwjbes7mle ON defermentaccount(division_Deferment_Join_Column); – 2014-11-21 16:35:05

回答

0

兩件事情:

  • defm並不似乎是一個列,以便將其更改爲*或你想要的列。
  • 也= =在這裏不需要,因爲你正在做一個左連接語法。我相信:=或=:是用於連接的舊ANSI樣式SQL。

SELECT * 
FROM DefermentAccount defm 
LEFT JOIN defm.division division 
ON division.divisionID=defm.defermentID 
+0

嗨謝謝,但我不是在SQL之後 - - 我需要JPQL語法。謝謝 - 我最初給出的SQL作品。 – 2014-11-21 16:41:26

+0

我覺得這個帖子可能會有答案:http://stackoverflow.com/questions/4992834/left-join-on-in-jpql - 但我不能讓查詢編譯SQL使用WHERE:它是推斷JPQL中沒有'ON' – 2014-11-21 16:52:56

0

我並不需要開啓,或者 - 它只有

作品 「SELECT defm,divis FROM DefermentAccount defm LEFT OUTER JOIN defm.division divis」