0

参考JPQL,我不清楚如何查询表。

我想要的是,如果它存在,@Entity Note对于给定的messagId 和组,但我不明白语法。

如何为以下查询指定 messageId 和组?

public void persist(Msg message) {
    LOG.info("\t" + message);
    LOG.info("isOpen?" + em.isOpen());
    em.getTransaction().begin();
    int id = message.getId();
    Query q = em.createQuery("SELECT  n "
            + "FROM Notes n WHERE n.messageId = :messageId "
            + "AND n.group = :group");
    List results = q.getResultList();
    em.getTransaction().commit();
    for (Object o : results) {
        LOG.info("object is \n\n" + o);
    }
}

}

4

2 回答 2

1

您需要使用 setParameter() 设置查询的参数。

见, http ://en.wikibooks.org/wiki/Java_Persistence/Querying#Parameters

于 2012-05-10T14:00:41.770 回答
1

使用setParameter(String name, Object value)

q.setParameter("messageId", id).setParameter("group", group);

为了使它更好,请使用TypedQuery

public void persist(Msg message) {
    LOG.info("\t" + message);
    LOG.info("isOpen?" + em.isOpen());
    em.getTransaction().begin();
    int id = message.getId();
    TypedQuery<Note> q = em.createQuery("SELECT  n "
            + "FROM Notes n WHERE n.messageId = :messageId "
            + "AND n.group = :group", Note.class);
    q.setParameter("messageId", id).setParameter("group", group);
    List<Note> results = q.getResultList();
    em.getTransaction().commit();
    for (Note o : results) {
        LOG.info("object is \n\n" + o);
    }
}
于 2012-05-10T14:02:00.107 回答