2011-01-11 13 views
2

SQLクエリに問題があります。私は、クエリを構築するためにHibernate Criteriaを使用しています。特定の間隔(binSize)で値を四捨五入してグループ化して、データベースからいくつかのビンを作成します。私は、クエリとSQLで直接それをしようとすると、これは素晴らしい作品:エラー:GROUP BY句に "this_.phitorsionangle"という列が表示されているか、集計関数で使用されている必要があります

 
SELECT floor(phiTorsionAngle/2) * 2 as phiTorsionAngleBin, 
     floor(psiTorsionAngle/2) * 2 as psiTorsionAngleBin, 
     floor(phiTorsionAngle/2) + 180 as phiTorsionAngleBinIndex, 
     floor(psiTorsionAngle/2) + 180 as psiTorsionAngleBinIndex, 
     count(*) as numberOfResidues 
FROM residue 

WHERE phitorsionangle IS NOT NULL 
    AND psitorsionangle IS NOT NULL 

GROUP BY phiTorsionAngleBin, psiTorsionAngleBin 

しかし、ときに私はそれが失敗したHibernateの基準でそれを試してみてください。これは、クエリを作成するためのコードです:

ScrollableResults phiPsiBins = createCriteria() 
.setProjection(Projections.projectionList() 
     .add(Projections.sqlGroupProjection(
     "floor(phiTorsionAngle/" + binSize + ") * " + binSize + " as phiTorsionAngleBin, " + 
     "floor(psiTorsionAngle/" + binSize + ") * " + binSize + " as psiTorsionAngleBin, " +   
     "floor(phiTorsionAngle/" + binSize + ") + 180 as phiTorsionAngleBinIndex, " + 
     "floor(psiTorsionAngle/" + binSize + ") + 180 as psiTorsionAngleBinIndex, " + 
     "count(*) as numberOfResidues", 
     "phiTorsionAngleBin, psiTorsionAngleBin", 
     new String[] {"phiTorsionAngleBin", "psiTorsionAngleBin", "phiTorsionAngleBinIndex", "psiTorsionAngleBinIndex", "numberOfResidues"}, 
     new Type[] {Hibernate.DOUBLE, Hibernate.DOUBLE, Hibernate.INTEGER, Hibernate.INTEGER, Hibernate.INTEGER}))) 
.add(Restrictions.isNotNull("phiTorsionAngle")) 
.add(Restrictions.isNotNull("psiTorsionAngle")) 
.setResultTransformer(Transformers.aliasToBean(PhiPsiBinResult.class)) 
.setCacheMode(CacheMode.IGNORE) 
.scroll(ScrollMode.FORWARD_ONLY); 

これは、以下の完全なスタックトレースで、私は取得していますエラーメッセージです:

 
ERROR: column "this_.phitorsionangle" must appear in the GROUP BY clause or be used in an aggregate function 

WARN 2011-01-11 16:13:43,047 main JDBCExceptionReporter:100 - SQL Error: 0, SQLState: 42803 
ERROR 2011-01-11 16:13:43,047 main JDBCExceptionReporter:101 - ERROR: column "this_.phitorsionangle" must appear in the GROUP BY clause or be used in an aggregate function 
    Position: 143 
Exception in thread "main" org.hibernate.exception.SQLGrammarException: could not execute query using scroll 
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:90) 
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66) 
at org.hibernate.loader.Loader.scroll(Loader.java:2340) 
at org.hibernate.loader.criteria.CriteriaLoader.scroll(CriteriaLoader.java:113) 
at org.hibernate.impl.SessionImpl.scroll(SessionImpl.java:1561) 
at org.hibernate.impl.CriteriaImpl.scroll(CriteriaImpl.java:320) 
at nl.ru.cmbi.pdbeter.core.controller.DAO.ResidueDAO.getPhiPsiBinSet(ResidueDAO.java:236) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:616) 
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:309) 
at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:183) 
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150) 
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110) 
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) 
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202) 
at $Proxy27.getPhiPsiBinSet(Unknown Source) 
at nl.ru.cmbi.pdbeter.statistics.controller.StatisticsFunctions.makeRamachandranPlot(StatisticsFunctions.java:26) 
at nl.ru.cmbi.pdbeter.statistics.controller.StatisticsMain.start(StatisticsMain.java:39) 
at nl.ru.cmbi.pdbeter.statistics.controller.StatisticsMain.main(StatisticsMain.java:33) 
Caused by: org.postgresql.util.PSQLException: ERROR: column "this_.phitorsionangle" must appear in the GROUP BY clause or be used in an aggregate function 
    Position: 143 
at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2062) 
at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1795) 
at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:257) 
at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:479) 
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:367) 
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeQuery(AbstractJdbc2Statement.java:271) 
at org.hibernate.jdbc.AbstractBatcher.getResultSet(AbstractBatcher.java:208) 
at org.hibernate.loader.Loader.getResultSet(Loader.java:1812) 
at org.hibernate.loader.Loader.scroll(Loader.java:2305) 
... 18 more 

私はGROUPにphiTorsionAngleとpsiTorsionAngleを追加してみましたBY、これはうまくいくようですが、それは意味をなさないものです。私はphiTorsionAngleのすべての可能な値でグループ分けしたくないので、私はビン全体をグループ化したいと思うでしょう。おそらく、phiTorsionAngleのための多くの異なる値を含んでいます。どうしてこのエラーが出るのですか?どうすれば回避できますか?

更新:実際にはまだ終了していないのにクエリを実行しようとはしませんでした。そして、ヒープスペースエラーが発生しました.PiTorsionAngleとpsiTorsionAngleグループ化するには今すぐ完全に質問です:)

+0

SQLログを有効にしてみてください:http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/session- configuration.html#configuration-logging – axtavt

答えて

0
SELECT phiTorsionAngleHalfFloor * 2 as phiTorsionAngleBin, 
     psiTorsionAngleHalfFloor * 2 as psiTorsionAngleBin, 
     phiTorsionAngleHalfFloor + 180 as phiTorsionAngleBinIndex, 
     psiTorsionAngleHalfFloor + 180 as psiTorsionAngleBinIndex, 
     numberOfResidues 
FROM (
     SELECT FLOOR(phiTorsionAngleHalf/2) AS phiTorsionAngleHalfFloor, 
       FLOOR(psiTorsionAngleHalf/2) AS psiTorsionAngleHalfFloor, 
       COUNT(*) AS numberOfResidues 
     FROM residue 
     WHERE phitorsionangle IS NOT NULL 
       AND psitorsionangle IS NOT NULL 
     GROUP BY 
       phiTorsionAngleHalfFloor, psiTorsionAngleHalfFloor 
     ) q 
+0

私は十分にはっきりしません。phiTorsionAngleまたはpsiTorsionAngleでグループ化することはできません。これは、クエリの目的を破るためです。私はphiTorsionAngleBinとpsiTorsionAngleBinのグループが必要です。さらに、あなたが私のアップデートで読むことができるように:あなたがJavaで言うことは、約1900万の結果をメモリにロードしようとするため、ヒープ・スペース・エラーになります。 – FinalArt2005

+0

@FinalArt:申し訳ありませんが、あなたのモデルは間違っています。ポストアップデートを参照してください。 – Quassnoi

関連する問題