java - .add() 操作上的 GAE JDO NullPointerException

标签 java google-app-engine jdo

我试图在 GAE 中建立一对多关系,当我添加到列表时,我收到以下错误:

[java] java.lang.NullPointerException
 [java]     at com.google.appengine.datanucleus.scostore.FKListStore.getIndexPropertyName(FKListStore.java:965)
 [java]     at com.google.appengine.datanucleus.scostore.FKListStore.getFilterPredicates(FKListStore.java:940)
 [java]     at com.google.appengine.datanucleus.scostore.FKListStore.listIterator(FKListStore.java:383)
 [java]     at com.google.appengine.datanucleus.scostore.FKListStore.listIterator(FKListStore.java:349)
 [java]     at com.google.appengine.datanucleus.scostore.FKListStore.iterator(FKListStore.java:342)
 [java]     at org.datanucleus.store.types.sco.backed.List.loadFromStore(List.java:304)
 [java]     at org.datanucleus.store.types.sco.backed.List.add(List.java:685)
 [java]     at Utils.GardenUtils.PostMessage(GardenUtils.java:187)
 [java]     at Servlets.GardenServlets.PostGardenMessageServlet.processRequest(PostGardenMessageServlet.java:28)
 [java]     at Servlets.GardenServlets.PostGardenMessageServlet.doPost(PostGardenMessageServlet.java:70)
 [java]     at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
 [java]     at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
 [java]     at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)
 [java]     at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1166)
 [java]     at com.google.appengine.api.socket.dev.DevSocketFilter.doFilter(DevSocketFilter.java:74)
 [java]     at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
 [java]     at com.google.appengine.tools.development.ResponseRewriterFilter.doFilter(ResponseRewriterFilter.java:127)
 [java]     at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
 [java]     at com.google.appengine.tools.development.HeaderVerificationFilter.doFilter(HeaderVerificationFilter.java:34)
 [java]     at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
 [java]     at com.google.appengine.api.blobstore.dev.ServeBlobFilter.doFilter(ServeBlobFilter.java:63)
 [java]     at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
 [java]     at com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:43)
 [java]     at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
 [java]     at com.google.appengine.tools.development.StaticFileFilter.doFilter(StaticFileFilter.java:125)
 [java]     at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
 [java]     at com.google.appengine.tools.development.DevAppServerModulesFilter.doDirectRequest(DevAppServerModulesFilter.java:366)
 [java]     at com.google.appengine.tools.development.DevAppServerModulesFilter.doDirectModuleRequest(DevAppServerModulesFilter.java:349)
 [java]     at com.google.appengine.tools.development.DevAppServerModulesFilter.doFilter(DevAppServerModulesFilter.java:116)
 [java]     at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157)
 [java]     at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388)
 [java]     at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
 [java]     at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)
 [java]     at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765)
 [java]     at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418)
 [java]     at com.google.appengine.tools.development.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:98)
 [java]     at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
 [java]     at com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:491)
 [java]     at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
 [java]     at org.mortbay.jetty.Server.handle(Server.java:326)
 [java]     at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)
 [java]     at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:938)
 [java]     at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:755)
 [java]     at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:218)
 [java]     at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
 [java]     at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:409)
 [java]     at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)

这就是我添加新列表成员的方式:

    public static void PostMessage(String userID, String gardenKey, String content) {
    PersistenceManager pm = PMF.get().getPersistenceManager();

    try {
        User user = pm.getObjectById(User.class, userID);

        GardenMessage message = new GardenMessage();
        message.setFirstName(user.getFirstName());
        message.setLastName(user.getLastName());
        message.setUserID(userID);
        message.setContent(content);
        message.setGardenKey(gardenKey);
        message.setPostDate(new Date());

        Garden garden = pm.getObjectById(Garden.class, gardenKey);
        garden.getMessages().add(message);
    } finally {
        pm.close();
    }
}

在花园课上我有这个:

@Persistent
private List<GardenMessage> messages;

请让我知道我的代码有什么问题。

最佳答案

据我所知,Google 的插件在上次发布(2.1.2)后有过几次更新,但他们没有费心发布它。代码位于http://code.google.com/p/datanucleus-appengine/source/browse/#svn%2Ftrunk 你有NPE的那一行肯定和粗看不一样,所以建议你试试他们现在的SVN。您应该能够简单地进行检查,然后“mvn clean install”来获取版本 3.0.0-SNAPSHOT(使用 DataNucleus 3.2 IIRC)。

简单搜索也找到了这篇文章javax.jdo.JDOException: Unexpected error during precommit

关于java - .add() 操作上的 GAE JDO NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25483495/

相关文章:

java - 通过 Java 系统属性设置不正确的 http 代理主机时没有错误

java - Java 桌面应用程序有没有好的框架?

java - WebClient - 如何获取请求正文?

Google App Engine 标准环境中的 Java 堆转储?

java - 为什么我的更新不起作用?

java - GAE jdo是否不支持身份策略="timestamp"

java - XMLStreamException : Parse error

google-app-engine - Go 在 Google App Engine Datastore 中有很多关系

java - 提高 SQL 查询执行速度

python - 当存在多个订单属性时加快 App Engine 本地 SDK 数据库查询?