为啥我在 Google App Engine 上使用 JDO 的查询中出现转换错误?

Posted

技术标签:

【中文标题】为啥我在 Google App Engine 上使用 JDO 的查询中出现转换错误?【英文标题】:Why am I getting a cast error in my Query using JDO on Google App Engine?为什么我在 Google App Engine 上使用 JDO 的查询中出现转换错误? 【发布时间】:2010-11-04 18:19:09 【问题描述】:

根据the Queries and Indexes doc,您可以有效地进行查询(据我所知):

PersistenceManager pm = PMF.get().getPersistenceManager();
try 
    Query q = pm.newQuery(App.class);
    q.setOrdering("name desc");

    try 
        results = (ArrayList<App>) q.execute();
     finally 
        q.closeAll();
    
 finally 
    pm.close();

但是,results = (ArrayList<App>) q.execute(); 行出现以下错误:

java.lang.ClassCastException: org.datanucleus.store.appengine.query.StreamingQueryResult cannot be cast to java.util.ArrayList
    at com.killerrobots.AppSite.MainServlet.getApplications(MainServlet.java:66)
    at com.killerrobots.AppSite.MainServlet.doGet(MainServlet.java:26)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:693)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:806)
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1093)
    at com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:43)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:360)
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:712)
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
    at com.google.apphosting.utils.jetty.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:54)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:139)
    at com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:306)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:139)
    at org.mortbay.jetty.Server.handle(Server.java:313)
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:506)
    at org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:830)
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:514)
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:381)
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:396)
    at org.mortbay.thread.BoundedThreadPool$PoolThread.run(BoundedThreadPool.java:442)

有什么想法吗?

【问题讨论】:

【参考方案1】:

您可以将execute 的结果转换为List&lt;whatever&gt;,但不能专门转换为ArrayList&lt;whatever&gt;,这是您的代码正在尝试执行的操作!为什么不直接使用List,即允许您转换为的抽象,而不是ArrayList,您不允许转换为的具体实现?

【讨论】:

废话...我知道我看代码太久了。错过了明显的。谢谢。

以上是关于为啥我在 Google App Engine 上使用 JDO 的查询中出现转换错误?的主要内容,如果未能解决你的问题,请参考以下文章

为啥 Google App Engine 文档强调 JDO 而不是 JPA?

为啥 Google 删除了运行 Python 3.7 的 App Engine 的 Image API?

Google App Engine 和 Django 模板:为啥这两种情况不同?

我在哪里可以看到Google App Engine中的日志?

连接 Google App Engine 和 Google Compute Engine

如何从我在 Google App Engine SDK 上运行的 Python 应用程序访问本地 MySQL 实例?