1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

EntityManager método find() não encontra objetos recém inseridos no bd!

Olá galera, leiam o comentário e entenderão!

Obs.: Estou utilizando Jersey, MySQL e JPA + Hibernate

    @Override
    public UsuarioR buscar(Long id_usuario_r) {

        EntityManager em = Factory.FACTORY.createEntityManager();

        /*
         * Fazendo essa gambiarra funciona, de outro jeito não consegui fazer
         * funcionar! Quando um elemento foi recentemente inserido, o método
         * "find()" simplesmente não o encontra, é como se o banco não se
         * atualiza-se com os "commits()" dos métodos de inserção!
         */
        em.getTransaction().begin();
        em.getTransaction().commit();

        UsuarioR uR = em.find(UsuarioR.class, id_usuario_r);

        em.close();

        return uR;
    }

Desde já agradeço, essa vai ser minha primeira aplicação e gostaria de ter certeza que ao oferecê-la por aí, ela não dê problemas!

Editado:

Abaixo segue o código do método de adição de usuários, esses usuários são padronizados e serão quatro, por isso dos objetos já definidos! Segue código:

    @Override
    public void adicionar(UsuarioR uR) {

        EntityManager em = Factory.FACTORY.createEntityManager();

        em.getTransaction().begin();

        Util u = new Util();

        Representante r = new Representante();
        r.setId_representante((long) 1);

        uR.setLogin("");
        uR.setSenha(u.gerarSenha(listar()));
        uR.setRepresentante(r);
        uR.setBloqueado(false);

        em.persist(uR);

        uR.setLogin(u.gerarLogin(uR.getId_usuario_r()));

        em.merge(uR);

        uR = new UsuarioR();
        uR.setLogin("");
        uR.setSenha(u.gerarSenha(listar()));
        uR.setRepresentante(r);
        uR.setBloqueado(false);

        em.persist(uR);

        uR.setLogin(u.gerarLogin(uR.getId_usuario_r()));

        em.merge(uR);

        r = new Representante();
        r.setId_representante((long) 2);

        uR = new UsuarioR();
        uR.setLogin("");
        uR.setSenha(u.gerarSenha(listar()));
        uR.setRepresentante(r);
        uR.setBloqueado(false);

        em.persist(uR);

        uR.setLogin(u.gerarLogin(uR.getId_usuario_r()));

        em.merge(uR);

        uR = new UsuarioR();
        uR.setLogin("");
        uR.setSenha(u.gerarSenha(listar()));
        uR.setRepresentante(r);
        uR.setBloqueado(false);

        em.persist(uR);

        uR.setLogin(u.gerarLogin(uR.getId_usuario_r()));

        em.merge(uR);

        em.getTransaction().commit();

        em.flush();

        em.close();
    }
  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

3 respostas

Não é a resposta que estava procurando? Procure outras perguntas com as tags webservices rest jersey mysql hibernate ou faça a sua própria pergunta.