使用实体管理器本机查询插入我的JPA

使用实体管理器本机查询插入我的JPA,jpa,entitymanager,Jpa,Entitymanager,我试图在我的数据库中插入一个数据,我在我的项目中使用JPA 这就是我的豆子的样子 @PersistenceContext EntityManager em; em.createNativeQuery("INSERT INTO testtable ('column1','column2') VALUES ('test1','test2')").executeUpdate(); myfacade: @Stateless public class TestFacade extends Ab

我试图在我的数据库中插入一个数据,我在我的项目中使用JPA

这就是我的豆子的样子

@PersistenceContext
EntityManager em;

    em.createNativeQuery("INSERT INTO testtable ('column1','column2') VALUES ('test1','test2')").executeUpdate();
myfacade:

@Stateless
public class TestFacade extends AbstractFacade<Test> {
    @PersistenceContext(unitName = "TEST2PU")
    private EntityManager em;

    @Override
    protected EntityManager getEntityManager() {
        return em;
    }

    public TestFacade() {
        super(Test.class);
    }
如果我没有为EntityManager使用
@PersistenceContext

EntityManagerFactory emf = Persistence.createEntityManagerFactory("TEST2PU");
EntityManager em = emf.createEntityManager();
em.createNativeQuery("INSERT INTO testtable ('column1','column2') VALUES ('test1','test2')").executeUpdate();
这是我的错误:

javax.persistence.TransactionRequiredException: 
Exception Description: No externally managed transaction is currently active for this thread

注意:这确实需要使用本机查询。

假设您使用的是容器管理的
entityManager
(注入了
@PersistenceContext
),那么您就错过了TestFacade方法上方的
@Transactionnal
注释。

我也遇到了同样的问题。这是解决办法

EntityManager em = getEntityManager();
EntityTransaction et = em.getTransaction();
et.begin();
em.createNativeQuery("UPDATE ... ;").executeUpdate();
et.commit();

您可以使用NativeQuery及其executeUpdate方法执行此操作:

String query = "insert into Employee values(1,?)";

em.createNativeQuery(query)
   .setParameter(1, "Tom")
   .executeUpdate();
String message=”“;
尝试
{
EntityManager em=emf.createEntityManager();

如果(objUser.getId(),这个问题与JSF完全无关。您启动了事务吗?或者您使用什么进行事务管理?如何使用此查询获取最后一个插入的id?@KumaresanPerumal您已经发现了吗?还想知道这是否正确possible@KumaresanPerumal“插入表(a,b)中返回id的值('a','b')尝试将其与getResultList()和postgresql结合使用。一些解释将显著提高答案的质量。我们如何将其用于批量插入
String query = "insert into Employee values(1,?)";

em.createNativeQuery(query)
   .setParameter(1, "Tom")
   .executeUpdate();
 String message = "";
    try
    {
        EntityManager em = emf.createEntityManager();
        if (objUser.getId() <= 0)
        {
            em.getTransaction().begin();
            em.createNativeQuery("INSERT INTO userinfo ( login, upassword, email, mobile, fax, dob)"
                    + " VALUES ( :a, :b, :c, :d, :e, :f)")
                    .setParameter("a", objUser.getLogin())
                    .setParameter("b", objUser.getUpassword())
                    .setParameter("c", objUser.getEmail())
                    .setParameter("d", objUser.getMobile())
                    .setParameter("e", objUser.getFax())
                    .setParameter("f", objUser.getDob()).executeUpdate();
            em.getTransaction().commit();
            em.close();
            message = "Success";
        }
    } catch (HibernateException ex)
    {
        message = ex.getMessage();
    }