【发布时间】:2012-11-22 22:53:29
【问题描述】:
我正在 Google App Engine/Java 上开发一个应用程序。 在我的开发环境中,应用程序运行良好,数据存储和检索成功。但是,在上传到应用程序引擎时,我不断收到错误“javax.jdo.JDOFatalUserException:非法参数”。从堆栈跟踪来看,这似乎发生在我调用 (List query.execute()).size() 时。 相关的堆栈跟踪是。
2012-11-22 23:34:08.512
[s~qalmadev1/1.363360558551053190].<stderr>: javax.jdo.JDOFatalUserException: Illegal argument
W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>: at org.datanucleus.api.jdo.NucleusJDOHelper.getJDOExceptionForNucleusException(NucleusJDOHelper.java:488)
W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>: at org.datanucleus.api.jdo.JDOAdapter.getApiExceptionForNucleusException(JDOAdapter.java:1107)
W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>: at com.google.appengine.datanucleus.query.QueryExceptionWrappers$2.get(QueryExceptionWrappers.java:72)
W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>: at com.google.appengine.datanucleus.query.RuntimeExceptionWrappingIterator.hasNext(RuntimeExceptionWrappingIterator.java:103)
W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>: at com.google.appengine.datanucleus.query.LazyResult.resolveAll(LazyResult.java:120)
W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>: at com.google.appengine.datanucleus.query.LazyResult.size(LazyResult.java:115)
W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>: at com.google.appengine.datanucleus.query.StreamingQueryResult.size(StreamingQueryResult.java:151)
W 2012-11-22 23:34:08.516
[s~qalmadev1/1.363360558551053190].<stderr>: at com.xxx.xxx.appengine.server.CreateEventServlet.doPost(CreateEventServlet.java:115)
我的 CreateEventServlet 中的第 115 行是下面代码中的“if()”行
Query query = pm.newQuery("select from com.xxx.xxx.appengine.User "
+ "where key == :userid");
List<User> result = (List<User>) query.execute(userid);
if (result != null && result.size() > 0) { // Line 115
user = result.get(0);
USER_VALID = true;
}
【问题讨论】:
-
您是否明确将您的实体名称设置为
com.xxx.xxx.appengine.User?如果不只是在查询中使用select from User。 -
我个人会打印出嵌套异常,这是真正的异常,它会告诉您实际存在问题的行(在公开可见的开源插件代码中)
标签: java google-app-engine google-cloud-datastore jdo