2009-07-09 24 views
1

asked question詢問是否有可能使用Java將複雜的類組合保存到Google AppEngine中的Google Datastore中,但我並不清楚並懶得發佈我的所有類,但是經過很多小時的鬥爭,我開始放棄。所以這裏有更詳細的代碼問題。從Google Datastore獲取對象後空白

我知道這種東西應該可以正常工作,但對於某些未知的原因,對我來說這不起作用。問題是,當我保存我的對象並關閉數據庫連接,然後再次打開它的數據在該對象中是空白的。該對象在數據庫中,當我選擇該對象的ID時,我可以看到它,但其他所有內容都是空白的。不幸的是,Google沒有數據庫查看器來查看數據庫中的內容。我試圖搜索和ask一個,但沒有運氣。 (有one但它的not working on my computer) 所以,在這裏我們去:

內容

// imports... 
@PersistenceCapable(identityType = IdentityType.APPLICATION) 
public class Content{ 

@PrimaryKey 
@Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY) 
@Extension(vendorName="datanucleus", key="gae.encoded-pk", value="true") 
private String id; 

@Persistent protected String title; 
@Persistent protected String thumbnailURL; 
@Persistent protected List<Rating> ratings; 
@Persistent protected List<Tag> tags; 
@Persistent protected Double price; 
@Persistent protected User owner; 

// constructor and getters+setters 
} 

// imports... 
@PersistenceCapable(identityType = IdentityType.APPLICATION) 
public class Course extends Content{ 

@Persistent private Video video; 
@Persistent private Document document; 
@Persistent private String notes; 
@Persistent private String summary; 

// constructor and getters+setters 
    public String toString(){ 
    return "ID: " + this.getId() + " Title: "+this.getTitle()+", Price: "+this.getPrice()+", No. of Tags: "+this.getTags().size(); 
} 

} 

視頻

// imports... 
public class Video extends Content { 
    @PrimaryKey 
    @Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY) 
    @Extension(vendorName="datanucleus", key="gae.encoded-pk", value="true") 
    String id; 

    @Persistent String fileUrl; 

    // constructor and getters+setters 
} 

文件

// imports... 
@PersistenceCapable(identityType = IdentityType.APPLICATION) 
public class Document extends Content /*AthenaObject*/ { 
@PrimaryKey 
@Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY) 
@Extension(vendorName="datanucleus", key="gae.encoded-pk", value="true") 
private String id; 

@Persistent private String docUrl; 

// constructor and getters+setters 
} 

標籤

// imports... 
@PersistenceCapable(identityType = IdentityType.APPLICATION) 
public class Tag{ 
@PrimaryKey 
@Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY) 
@Extension(vendorName="datanucleus", key="gae.encoded-pk", value="true") 
private String id; 

@Persistent private String tagText; 

// constructor and getters+setters 
} 

代碼堅持從數據存儲中獲取數據:

public Boolean testCourse(){ 
Boolean isSaved = false; 
PersistenceManager pm = PMF.get().getPersistenceManager(); 
Course c = new Course(); 
try{ 
    List<Tag> tags = new ArrayList<Tag>(); 
    tags.add(new Tag("tag1")); 
    tags.add(new Tag("tag2")); 
    tags.add(new Tag("tag3")); 


    c.setTitle("Course Title - " + new Date().getTime()); 
    c.setPrice(99.90); 
    c.setTags(tags); 

    System.out.println(c.toString()); // **Output:** ID: null Title: Course Title - 1247116147858, Price: 99.9, No. of Tags: 3 
    pm.makePersistent(c); 

    Course cAfter = pm.getObjectById(Course.class, KeyFactory.stringToKey(c.getId())); 
    System.out.println(cAfter.toString()); // **Output:** agptYRtzaWL4gZDb3Vy4ErYFgw Title: Course Title - 1247116147858, Price: 99.9, No. of Tags: 3 
    isSaved = true; 
} 
catch(Exception e){ 
    e.printStackTrace(); 
    isSaved = false; 
} 
finally{ 
    pm.close(); 
} 


pm = PMF.get().getPersistenceManager(); 

try{ 

    Course cAfterClose = pm.getObjectById(Course.class, KeyFactory.stringToKey(c.getId())); 
    System.out.println(cAfterClose.toString()); // **Error**: See below 
} 
catch(Exception e){e.printStackTrace();} 
finally{pm.close();} 


return isSaved; 
} 

這裏是輸出:

ID:nullTitle:課程名稱 - 1247117389679,價錢:99.9,的 標籤號:3 ID:agptYWtzaW1zYXBwcgwLEgZDb3Vyc2UYGAwTitle: 課程名稱 - 1247117389679,價錢: 99.9,標籤號:3的java。 lang.NullPointerException在 com.athena.server.entity.Course.toString(Course.java:94) 在 com.athena.server.CourseServiceImpl.testCourse(CourseServiceImpl.java:146) 在 sun.reflect.NativeMethodAccessorImpl .invoke0(原生 方法) sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 在 java.lang.reflect.Method.invoke(Method.java:585) 在 com.google.gwt.user.server.rpc .RPC.invokeAndEncodeResponse(RPC.java:527) at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:166) at com.google.gwt.user.server.rpc .RemoteServiceServlet.doPost(RemoteServiceServlet.java:86) 在 javax.servlet.http.HttpServlet.service(HttpServlet.java:713) 在 的javax.servlet。http.HttpServlet.service(HttpServlet.java:806) 在 org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487) 在 org.mortbay.jetty.servlet.ServletHandler $ CachedChain.doFilter( ServletHandler.java:1093) 在 com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:43) 在 org.mortbay.jetty.servlet.ServletHandler $ CachedChain.doFilter(ServletHandler.java: 1084) 在 org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:360) 在 org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) 在 org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181) 在 org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:712) 在 org.mortbay.jetty.webapp .WebAppContext.handle(WebAppContext.java:405) 在 com.google.apphosting.utils.jetty.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:54) 在 org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper的.java:139) 在 com.google.appengine.tools.development.JettyContainerService $ ApiProxyHandler.handle(JettyContainerService.java:306) 在 org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:139 ) 在 org.mortbay.jetty.Server.handle(Server.java:313) 在 org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:506) 在 org.mortbay.jetty.HttpConnection $ RequestHandler 。內容(HttpConnection.java:844) 在 org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:644) 在 org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211) 在 org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:381) 在 org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:396) 在 org.mortbay.thread.BoundedThreadPool $ PoolThread.run(BoundedThreadPool.java:442)

我知道這個錯誤意味着該字符串爲空。但是記錄在數據庫中。它應該堅持下去。爲什麼數據是空白的?

任何建議爲什麼發生在我身上?

回答

1

我不知道到底是什麼導致你的錯誤,但是這裏有幾個步驟,你可以嘗試幫助排除故障:

首先,嘗試將問題縮小到儘可能小的測試用例成爲可能。你有很多上面發佈的類,很可能這個問題只有2個或3個可能被複制。其次,如果你確實想看到你的實體在數據存儲中的樣子,你必須做這樣的事情(或者你可以嘗試上傳你的應用到appengine並在那裏運行它,這樣你就可以使用他們的數據查看器):

Query q = pm.newQuery(Course.class); 
List<Course> list = (List<Course>) q.execute(); 
for(Course c: list){ 
    System.out.println("Course id:" + c.getId()); 
    System.out.println("Course title:" + c.getTitle()); 
    //... 
}