【问题标题】:Update query in google app engine data store (java)更新谷歌应用引擎数据存储中的查询(java)
【发布时间】:2011-02-10 09:46:19
【问题描述】:

在使用 gwt 时如何在谷歌应用引擎中使用更新查询。我正在尝试制作一个聊天应用程序,除了提交和删除以前的消息外,管理员还可以编辑现有消息的部分。

为了编辑现有的消息,需要更新查询,我在数据存储中找不到类似更新查询的东西。

我们如何更新现有数据?

【问题讨论】:

  • GWT 的使用有何相关性?我是否理解以下回答中的问题?如果不能,我们可以互相引导正确的方向吗?

标签: java google-app-engine jpa jdo


【解决方案1】:

这是来自http://www.ibm.com/developerworks/java/library/j-gaej3.html 的一些示例代码 您可以先获取修改数据,然后再进行持久化,然后提交。

见附件代码中的 updateContact() 方法。

主要需要注意的是跨实体执行此操作 - 注意:DataStore 中的数据存储不同于关系数据库。

package gaej.example.contact.server;

import gaej.example.contact.client.Contact;

import java.util.List;

import javax.jdo.JDOHelper;
import javax.jdo.PersistenceManager;
import javax.jdo.PersistenceManagerFactory;

public class ContactJdoDAO implements ContactDAO {
    private static final PersistenceManagerFactory pmfInstance = JDOHelper
            .getPersistenceManagerFactory("transactions-optional");

    public static PersistenceManagerFactory getPersistenceManagerFactory() {
        return pmfInstance;
    }

    public void addContact(Contact contact) {
        PersistenceManager pm = getPersistenceManagerFactory()
                .getPersistenceManager();
        try {
            pm.makePersistent(contact);
        } finally {
            pm.close();
        }
    }

    @SuppressWarnings("unchecked")
    public List<Contact> listContacts() {
        PersistenceManager pm = getPersistenceManagerFactory()
                .getPersistenceManager();
        String query = "select from " + Contact.class.getName();
        return (List<Contact>) pm.newQuery(query).execute();
    }

    public void removeContact(Contact contact) {
        PersistenceManager pm = getPersistenceManagerFactory()
                .getPersistenceManager();
        try {
            pm.currentTransaction().begin();

            // We don't have a reference to the selected Product.
            // So we have to look it up first,
            contact = pm.getObjectById(Contact.class, contact.getId());
            pm.deletePersistent(contact);

            pm.currentTransaction().commit();
        } catch (Exception ex) {
            pm.currentTransaction().rollback();
            throw new RuntimeException(ex);
        } finally {
            pm.close();
        }
    }

    public void updateContact(Contact contact) {
        PersistenceManager pm = getPersistenceManagerFactory()
                .getPersistenceManager();
        String name = contact.getName();
        String phone = contact.getPhone();
        String email = contact.getEmail();

        try {
            pm.currentTransaction().begin();
            // We don't have a reference to the selected Product.
            // So we have to look it up first,
            contact = pm.getObjectById(Contact.class, contact.getId());
            contact.setName(name);
            contact.setPhone(phone);
            contact.setEmail(email);
            pm.makePersistent(contact);
            pm.currentTransaction().commit();
        } catch (Exception ex) {
            pm.currentTransaction().rollback();
            throw new RuntimeException(ex);
        } finally {
            pm.close();
        }
    }

}

【讨论】:

    【解决方案2】:

    对已检索或先前插入的实体调用 makePersistent() 将更新数据存储区中的实体。见the docs

    【讨论】:

    • 那么 pm.refresh(Object o) 有什么用呢?我认为这是应用引擎中 jdo 中的“更新”功能。 (至少它有效)
    猜你喜欢
    • 2014-10-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-05-17
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-05-13
    相关资源
    最近更新 更多