|
[size=0.76em]参考学习指南:http://code.google.com/intl/zh-CN/appengine/
[size=0.76em]使用jdo时遇到一个,如下代码:
[size=0.76em]private void listEmployees(HttpServletRequest req) {
[size=0.76em]PersistenceManager pm = PMF.get().getPersistenceManager();
[size=0.76em]String query = "select from " + Employee.class.getName() + " order by id ";
[size=0.76em]try {
[size=0.76em]List<Employee> list = (List<Employee>) pm.newQuery(query).execute();
[size=0.76em]list.size();
[size=0.76em]req.setAttribute("employees", list);
[size=0.76em]} finally {
[size=0.76em]pm.close();
[size=0.76em]}
[size=0.76em]}
[size=0.76em]添了红色的一句解决问题了。
[size=0.76em]本来没写红色的那句跳转到页面是就报
[size=0.76em]
[size=0.76em]org.apache.jasper.JasperException: An exception occurred processing JSP page /index.jsp at line 40
[size=0.76em]37: System.out.println("exc");
[size=0.76em]38: }
[size=0.76em]39: }
[size=0.76em]40: if (employees == null || employees.size() == 0) {
[size=0.76em]41: %>
[size=0.76em]42: <tr>
[size=0.76em]43: <td colspan="5" style='text-align: right'>无数据</td>
[size=0.76em]Caused by: org.datanucleus.exceptions.NucleusUserException:Object Manager has been closed错误。哦,原来是pm.close();,我的确关了,关了的确是不好使用关之前的值,但我也把值读出来放在了req.setAttribute("employees", list);中了啊。先不管我了,我把pm.close();关了果然解决了问题。于是想到了pm.newQuery(query).execute();可能有点问题,这让我联想到了Hibernate的load和get方法的区别,他的值也许不是直接取出来的,是放在缓存里的,在pm.close();之前没使用就失效了,关了之后使用就报错了。所以我在关之前使用下了list.size();使用list.size()没有别的意思,仅仅是使用下为了从缓存中取出来,这样就可以在关了之后继续使用。这样问题解决了。
[size=0.76em]刚用的还没认真看,也许有别的方法直接取出来,还没看先写下了笔记。我现在有两种解决方法,一种是等会执行pm.close();但这样开支太大,所以用第二种使用下list,即把他从缓存中取出。
[size=0.76em]附件:
[size=0.76em]1做了个crud的小应用(访问地址:http://gzhuyangjun.appspot.com/)
[size=0.76em]2学习资料
|
|
|
|
|
|
|