4
respostas

Preço e Tipo NULL

Não estou conseguindo inserir os valores na minha tabela, ambos os campos aparece NULL, mesmo depois da alteração indicada na aula anterior. Seguem os códigos:

FORM

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Livros de Java, Android, iPhone, Ruby, PHP e muito mais -
    Casa do Código</title>
</head>
<body>

    <form action="/casadocodigo/produtos" method="post">
        <div>
            <label>Titulo</label> <input type="text" name="titulo">
        </div>
        <div>
            <label>Descrição</label>
            <textarea rows="10" cols="20" name="descricao"></textarea>
        </div>
        <div>
            <label>Páginas</label> <input type="text" name="paginas">
        </div>
        <c:forEach items="${tipos }" var="tipoPreco" varStatus="status">
            <div>
                <label>${tipoPreco }</label> 
                <input type="text" name="precos[${status.index}].valor"> 
                <input type="hidden" name="precos[${status.index}].tipo" value="${tipoPreco }">
            </div>
        </c:forEach>


        <button type="submit">Cadastrar</button>
    </form>

</body>
</html>
4 respostas

PRODUTO

package br.com.casadocodigo.loja.models;

import java.util.List;

import javax.persistence.ElementCollection;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
public class Produto {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private int id;

    private String titulo;
    private String descricao;
    private int paginas;
    @ElementCollection
    private List<Preco> precos;

    public String getTitulo() {
        return titulo;
    }

    public void setTitulo(String titulo) {
        this.titulo = titulo;
    }

    public String getDescricao() {
        return descricao;
    }

    public void setDescricao(String descricao) {
        this.descricao = descricao;
    }

    public int getPaginas() {
        return paginas;
    }

    public void setPaginas(int paginas) {
        this.paginas = paginas;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public List<Preco> getPrecos() {
        return precos;
    }

    public void setPrecos(List<Preco> precos) {
        this.precos = precos;
    }

    @Override
    public String toString() {
        return "Produto [nome=" + titulo + ", descricao=" + descricao + ", paginas=" + paginas + "]";
    }

}

PREÇO

package br.com.casadocodigo.loja.models;

import java.math.BigDecimal;

import javax.persistence.Embeddable;

@Embeddable
public class Preco {

    private BigDecimal valor;
    private TipoPreco tipo;

    public BigDecimal getPreço() {
        return valor;
    }

    public void setPreço(BigDecimal preço) {
        this.valor = preço;
    }

    public TipoPreco getTipo() {
        return tipo;
    }

    public void setTipo(TipoPreco tipo) {
        this.tipo = tipo;
    }

}

PRODUTOSCONTROLLER

package br.com.casadocodigo.loja.controllers;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

import br.com.casadocodigo.loja.daos.ProdutoDAO;
import br.com.casadocodigo.loja.models.Produto;
import br.com.casadocodigo.loja.models.TipoPreco;

@Controller
public class ProdutosController {

    @Autowired
    private ProdutoDAO produtoDao;

    @RequestMapping("/produtos/form")
    public ModelAndView form() {
        ModelAndView modelAndView = new ModelAndView("produtos/form");
        modelAndView.addObject("tipos", TipoPreco.values());

        return modelAndView;

    }

    @RequestMapping("/produtos")
    public String grava(Produto produto) {
        System.out.println(produto);
        produtoDao.gravar(produto);
        return "produtos/ok";
    }

}

TIPOPRECO

package br.com.casadocodigo.loja.models;

public enum TipoPreco {
    EBOOK, IMPRESSO, COMBO;

}

Olá Rodrigo, tudo bem? Peço desculpas pela demora no retorno! Mas você fez alguma alteração nas anotações (annotations) das classes Produto e ou Preço? Bem, o que eu indico é que exclua todas as tabelas do banco de dados e crie novamente, as vezes quando fazemos alterações nessas anotações elas não são passadas diretamente para o banco, só se excluirmos a tabela e adicionarmos novamente. Então poderia tentar essa solução, e fala pra gente se deu certo?!