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

salvar uma List<UploadedFile> no banco

Boa tarde. Desejo salvar no banco, uma lista de arquivos após o upload.

Me corrijam por favor, se eu estiver errado.

Tenho uma classe Email como entidade e nela um atributo:


@OneToMany(fetch = FetchType.LAZY, mappedBy = "email")
    private List<Anexo> anexos;

Na classe Anexo, o atributo:

    private String nome;
@ManyToOne
    private Email email;

Não sei como proceder no controle para que ele insira a lista de anexos.

public void salvaAnexo(Email email, Anexo anexos, List<UploadedFile> files) {

for (UploadedFile uf : files) {            
            anexos.setNome(uf.getFileName());
             System.out.println(uf.getFileName());

        }

        this.daoFactory.getEmailDao().salva(email);
        this.daoFactory.getAnexoDao().salva(anexos);

result.redirectTo(this).lista();
}

O Log do console apresenta:

Criando Session...........
METODO JSON: -1METODO2: salvaAnexo: teste.pdf
exception raised, check root cause for details: java.lang.Exception: Ocorreu um erro a tentar inserir: could not insert: [br.com.modelo.Anexo]
Fechando Session...........

Poderiam por favor me ajudar nesse método?

++++++++++++++++++++++

Conforme as orientações que recebi, já estou salvando no banco alguns dados de email como: destinatario, assunto e texto

Quanto ao anexo, não estou salvando os dados, apenas o nome do anexo e estou com o seguinte problema:

Tenho por exemplo 2 anexos: anexo.pdf e anexo2.pdf

Quando vou salvar essas informações no banco, ocorre que estou sobrescrevendo o anterior.

Criando Session...........
METODO JSON: -1METODO2: enviarOrcamentoUsuario: trueHibernate: insert into atendimento.email (assunto, cc, cco, corpo, destinatario, nome_destinatario, proposta_proposta_cod) values (?, ?, ?, ?, ?, ?, ?)
anexo1.pdf
Hibernate: insert into atendimento.anexo (nome, proposta_proposta_cod) values (?, ?)
anexo2.pdf
Hibernate: update atendimento.anexo set nome=?, proposta_proposta_cod=? where anexo_cod=?
Fechando Session...........

Pelo que entendi, meu método insere no banco o primeiro anexo e o segundo ele faz um update (Aff)

for (UploadedFile f : files) {

             anexo.setProposta(proposta);
             anexo.setNome(uf.getFileName());            
            System.out.println(f.getFileName());
            this.daoFactory.getAnexoDao().salva(anexo);            
        }

Ou seja, tenho uma lista com "x" elementos e fico fazendo update... como como adicionar um a um e salvar?

  • email.setAnexos(anexos) e salva apenas o email.

    Thomas Teixeira   17 de abr de 2015
  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!

1 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags vraptor upload ou faça a sua própria pergunta.