J'essaie d'insérer des données dans ma base de données, j'utilise JPA dans mon projet.
Voici à quoi ressemble ma fève.
@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);
}
je reçois une erreur:
javax.persistence.TransactionRequiredException: executeUpdate is not supported for a Query object obtained through non-transactional access of a container-managed transactional EntityManager
et si je n'utilise pas @PersistenceContext for EntityManager
EntityManagerFactory emf = Persistence.createEntityManagerFactory("TEST2PU");
EntityManager em = emf.createEntityManager();
em.createNativeQuery("INSERT INTO testtable ('column1','column2') VALUES ('test1','test2')").executeUpdate();
c'est mon erreur:
javax.persistence.TransactionRequiredException:
Exception Description: No externally managed transaction is currently active for this thread
note: vraiment besoin d'utiliser une requête native pour cela.
Vous pouvez le faire en utilisant NativeQuery et sa méthode executeUpdate:
String query = "insert into Employee values(1,?)";
em.createNativeQuery(query)
.setParameter(1, "Tom")
.executeUpdate();
J'ai eu le même problème. Voici la solution.
EntityManager em = getEntityManager();
EntityTransaction et = em.getTransaction();
et.begin();
em.createNativeQuery("UPDATE ... ;").executeUpdate();
et.commit();
En supposant que vous utilisez la variable entityManager
gérée par le conteneur (injectée avec @PersistenceContext
), il vous manque une annotation @Transactionnal
au-dessus de votre méthode TestFacade.
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();
}