18

データベースにデータを挿入しようとしています。プロジェクトで JPA を使用しています。

これは私の豆がどのように見えるかです。

@PersistenceContext
EntityManager em;

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

マイファサード:

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

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

    public TestFacade() {
        super(Test.class);
    }

エラーが発生します:

javax.persistence.TransactionRequiredException: executeUpdate is not supported for a Query object obtained through non-transactional access of a container-managed transactional EntityManager

そして、私が使用しない場合@PersistenceContext for EntityManager

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

注:これにはネイティブクエリを使用する必要があります。

4

4 に答える 4

14

NativeQuery とその executeUpdate メソッドを使用して実行できます。

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

em.createNativeQuery(query)
   .setParameter(1, "Tom")
   .executeUpdate();
于 2014-09-13T15:33:19.983 に答える
9

私は同じ問題を抱えていました。これが解決策です。

EntityManager em = getEntityManager();
EntityTransaction et = em.getTransaction();
et.begin();
em.createNativeQuery("UPDATE ... ;").executeUpdate();
et.commit();
于 2014-06-06T10:31:30.080 に答える
4
 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();
    }
于 2018-03-18T16:48:17.217 に答える
3

コンテナ管理entityManager( を注入@PersistenceContext) を使用していると仮定すると@Transactionnal、TestFacade メソッドの上に注釈がありません。

于 2013-05-29T07:31:59.973 に答える