primefaces数据表更改了id错误的项(onrowedit)

xa9qqrwz  于 2021-06-29  发布在  Java
关注(0)|答案(0)|浏览(228)

我有一个bean可以从数据库中获取产品列表,我可以在onrowedit中正常地更改它,但是,当我在beanprod.searchprod()表单中搜索part方法时,它会用相关产品填充datatable,当我更改其中一些产品时,event.getobject()会使用不正确的id获取对象并更新不正确的产品。请帮帮我

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
    xmlns:ui="http://java.sun.com/jsf/facelets"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:p="http://primefaces.org/ui">
<h:head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <h:outputStylesheet name="a.css" library="css" />
</h:head>
<h:body>
    <div id="go">
        <p:panel id="basic" header="Adicionar Produto"
            style="margin-bottom:20px; width:400px">
            <p:panelGrid columns="4" style="margin:10px 0"/>
            <h:form id="form1" >

                <p:outputLabel value="Marca:" />
                <td>&nbsp;&nbsp;&nbsp;</td>
                <p:inputText id="marcacomp" value="#{beanProd.marcaProd}"
                    size="25" required="true" requiredMessage="#{beanMsgs.campovazio}" />
                <p:message for="marcacomp" />

                <br/>

                <p:outputLabel value="Nome:" />
                <td>&nbsp;&nbsp;&nbsp;</td>
                <p:inputText id="nome" value="#{beanProd.nomeProd}"
                    size="25" required="true" requiredMessage="#{beanMsgs.campovazio}" />
                <p:message for="nome" />

                <br/>

                <p:outputLabel value="Tamanho:" />
                <td></td>
                <p:inputText id="tamanho" value="#{beanProd.tamanhoProd}"
                    size="25" required="true" requiredMessage="#{beanMsgs.campovazio}"/>
                <p:message for="tamanho" />

                <br/>

                <p:commandButton id="button" value="Adicionar" ajax="false"
                    actionListener="#{beanProd.addUser()}" update="datatable"/>
                <p:messages id="messages" showDetail="true" closable="true" />
                <td></td>
                <td></td>
                <td></td>

                <br/>

            </h:form>
        </p:panel>

        <p:panel id="basic5" header="Buscar Produtos"
            style="margin-bottom:20px; width:380px">
            <p:panelGrid columns="1" />

            <h:form id="form10">

                <p:outputLabel value="Digite a busca:" />
                <br></br>
                <p:inputText id="buscaprod" value="#{beanProd.busca}"
                    size="25"  requiredMessage="#{beanMsgs.campovazio}" />

                <p:commandButton id="button3" value="Buscar" ajax="false"
                    actionListener="#{beanProd.searchProd()}" update="datatable" />

            </h:form>
        </p:panel>

        <h:form>
        <p:commandButton id="button5" value="INVERTER TODOS MOSTRAR" ajax="false"
                    actionListener="#{beanProd.alterarTodos()}" update="datatable" />
        </h:form>       
        </div>

    <div id="direita">
        <h:form id="form3">
            <p:dataTable id="datatable" value="#{beanProd.produtos}" var="p"
                editable="true" sortOrder="ascending" sortBy="#{p.id}"
                paginator="true" rows="10">
                <f:facet name="header">
        Lista de Produtos
    </f:facet>
                <p:ajax event="rowEdit" listener="#{beanProd.onRowEdit}" update="datatable"/>
                <p:ajax event="rowEditCancel" listener="#{beanProd.onRowCancel}" update="datatable"/>
                <p:column headerText="Marca"
                    style="width:70px; text-align: center;">
                    <p:cellEditor>
                        <f:facet name="output">
                            <h:outputText value="#{p.marcaProd}" />
                        </f:facet>
                        <f:facet name="input">
                            <p:inputText id="modelInput2" value="#{p.marcaProd}"
                                style="width:100%" />
                        </f:facet>
                    </p:cellEditor>
                </p:column>
                <p:column headerText="Nome"
                    style="width:110px; text-align: center;">
                    <p:cellEditor>
                        <f:facet name="output">
                            <h:outputText value="#{p.nomeProd}" />
                        </f:facet>
                        <f:facet name="input">
                            <p:inputText id="modelInput3" value="#{p.nomeProd}"
                                style="width:100%" />
                        </f:facet>
                    </p:cellEditor>
                </p:column>
                <p:column headerText="Tamanho"
                    style="width:70px; text-align: center;">
                    <p:cellEditor>
                        <f:facet name="output">
                            <h:outputText value="#{p.tamanhoProd}" />
                        </f:facet>
                        <f:facet name="input">
                            <p:inputText id="modelInput5" value="#{p.tamanhoProd}"
                                style="width:100%" />
                        </f:facet>
                    </p:cellEditor>
                </p:column>

                <p:column headerText="Mostrar"
                    style="width:50px; text-align: center;">
                    <p:cellEditor>
                        <f:facet name="output">
                            <h:outputText value="Não" rendered="#{p.mostrar == 0}" />
                            <h:outputText value="Sim" rendered="#{p.mostrar == 1}" />
                        </f:facet>
                        <f:facet name="input">
                            <p:selectOneMenu id="mastrar2"
                            value="#{beanProd.mostrar2}"
                            style="height:30px; width:70px" required="false">
                            <f:param name="mostrar2" value="#{beanProd.mostrar2}" />
                            <f:selectItem itemLabel="Sim" itemValue="Sim" />
                            <f:selectItem itemLabel="Nao" itemValue="Nao" />
                            </p:selectOneMenu>
                        </f:facet>
                    </p:cellEditor>
                </p:column>

                <p:column headerText="Acao" style="width:30px; text-align: center;">
                    <p:rowEditor editTitle="Editar" saveTitle="Salvar"
                        cancelTitle="Cancelar" />
                    <h:outputLabel id="editRow2">
                        <p:commandButton id="button" jax="false"
                            icon="ui-icon-circle-close" title="Excluir"
                            action="#{beanProd.deleteFromDB(p)}" update="datatable"
                            process="@this">

                            <p:confirm header="Confirmação" message="Tem certeza que deseja excluir este usuario?"
                                icon="pi pi-exclamation-triangle" />
                                </p:commandButton>

                        <p:confirmDialog global="true" showEffect="fade" hideEffect="fade">
                            <p:commandButton value="SIM" type="button"
                                styleClass="ui-confirmdialog-yes" />
                            <p:commandButton value="NÃO" type="button"
                                styleClass="ui-confirmdialog-no" />
                        </p:confirmDialog>

                        <p:message for="button" />
                    </h:outputLabel>
                    <p:tooltip for="editRow2" value="Excluir" showEffect="fade"
                        hideEffect="fade" />
                </p:column>
            </p:dataTable>
            </h:form>
    </div>
</h:body>
</html>

    package Bean;

import java.io.Serializable;
import java.sql.SQLException;
import java.util.ArrayList;

import javax.annotation.PostConstruct;
import javax.faces.application.FacesMessage;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
import javax.faces.context.FacesContext;

import org.primefaces.event.CellEditEvent;
import org.primefaces.event.RowEditEvent;

import DAO.DaoFactory;
import DAO.PredictDAO;
import Model.Produto;
import Model.Usuario;

@ManagedBean(name="beanProd")
@RequestScoped
public class BeanProd implements Serializable{

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    private Produto produto = new Produto();
    private ArrayList<Produto> produtos;
    private String marcaProd;
    private String nomeProd;
    private String tamanhoProd;
    private String busca;
    private String mostrar2;

    private boolean ativo;

    public BeanProd() {

    }

    @PostConstruct
    public void init() {
        buscarTodosProd();
    }

    public ArrayList<Produto> buscarTodosProd() {
        DaoFactory factory = new DaoFactory();
        factory.abrirConexao();
        PredictDAO dao = factory.criarPredictDAO();
        produtos = dao.buscaProdutos();
        factory.fecharConexao();
        return produtos;
    }

    public ArrayList<Produto> searchProd() {
        produtos.clear();
        DaoFactory factory = new DaoFactory();
        factory.abrirConexao();
        PredictDAO dao = factory.criarPredictDAO();
        produtos = dao.buscarUmProduto(busca);
        System.out.println(busca);
        factory.fecharConexao();
        return produtos;
    }

    public ArrayList<Produto> alterarTodos() {
        produtos.clear();
        DaoFactory factory = new DaoFactory();
        factory.abrirConexao();
        PredictDAO dao = factory.criarPredictDAO();
        produtos = dao.alterarTodosProdutos();
        factory.fecharConexao();
        return produtos;
    }

    public void addUser() {

        Produto produto = new Produto();
        produto.setMarcaProd(marcaProd);
        produto.setNomeProd(nomeProd);
        produto.setTamanhoProd(tamanhoProd);
        produto.setMostrar(1);

        DaoFactory factory = new DaoFactory();
        factory.abrirConexao();
        PredictDAO dao = factory.criarPredictDAO();
        dao.adicionarProduto(produto);
        factory.fecharConexao();
        produtos.add(produto);

        marcaProd = "";
        nomeProd = "";
        tamanhoProd = "";

    }

    public void deleteFromDB(Produto produto) {

        // FacesContext context = FacesContext.getCurrentInstance();
        int id;
        // int id = (Integer) event.getComponent().getAttributes().get("id2");
        DaoFactory factory = new DaoFactory();
        factory.abrirConexao();
        PredictDAO dao = factory.criarPredictDAO();
        // id =
        // Integer.parseInt(context.getExternalContext().getRequestParameterMap().get("idhidden"));
        try {
//          Map m = FacesContext.getCurrentInstance().getExternalContext().getRequestParameterMap();
//          System.out.println(m.toString());
            dao.excluirProduto(produto.getId());
            produtos.remove(produto);
            FacesContext.getCurrentInstance().addMessage("messages", new FacesMessage("Produto Excluido com Sucesso!"));

        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        factory.fecharConexao();

    }

    public void onRowEdit(RowEditEvent<Produto> event) {
        Produto promocao2 = new Produto();
        promocao2 = (Produto) event.getObject();

        System.out.println(promocao2.getId());

        DaoFactory factory = new DaoFactory();
        factory.abrirConexao();
        PredictDAO dao = factory.criarPredictDAO();

                    dao.atualizarProduto(promocao2);
                    factory.fecharConexao();

    }

    public void onRowCancel(RowEditEvent event) {
        System.out.println("Chamou onRowCancel!" + event.toString());
        FacesMessage msg = new FacesMessage("Edit Cancelled", "" + ((Produto) event.getObject()).getId());
        FacesContext.getCurrentInstance().addMessage(null, msg);
    }

    public boolean isAtivo() {
        return ativo;
    }

    public void setAtivo(boolean ativo) {
        this.ativo = ativo;
    }

    public Produto getProduto() {
        return produto;
    }

    public void setProduto(Produto produto) {
        this.produto = produto;
    }

    public ArrayList<Produto> getProdutos() {
        return produtos;
    }

    public void setProdutos(ArrayList<Produto> produtos) {
        this.produtos = produtos;
    }

    public String getMarcaProd() {
        return marcaProd;
    }

    public void setMarcaProd(String marcaProd) {
        this.marcaProd = marcaProd;
    }

    public String getNomeProd() {
        return nomeProd;
    }

    public void setNomeProd(String nomeProd) {
        this.nomeProd = nomeProd;
    }

    public String getTamanhoProd() {
        return tamanhoProd;
    }

    public void setTamanhoProd(String tamanhoProd) {
        this.tamanhoProd = tamanhoProd;
    }

    public static long getSerialversionuid() {
        return serialVersionUID;
    }

    public String getBusca() {
        return busca;
    }

    public void setBusca(String busca) {
        this.busca = busca;
    }

    public String getMostrar2() {
        return mostrar2;
    }

    public void setMostrar2(String mostrar2) {
        this.mostrar2 = mostrar2;
    }

    @Override
    public String toString() {
        return "BeanProd [produto=" + produto + ", produtos=" + produtos + ", marcaProd=" + marcaProd + ", nomeProd="
                + nomeProd + ", tamanhoProd=" + tamanhoProd + ", ativo=" + ativo + "]";
    }

}

很抱歉,这里缺少详细信息,这是我的第一篇文章,让我们转到datatable中所有产品的详细示例
以下是来自数据库的产品,它们用@postconstruct注解填充datatable init()方法
当我用creme这个词搜索左边的表单时,他调用searchprod方法q用包含creme这个词的产品填充datatable
搜索窗体填充数据表搜索字符串
如您所见,datatable中只填充了包含cream一词的产品
在搜索之前,我可以直接在datatable中更改产品通常它会正确更改数据库中的产品,但当我搜索包含特定单词的产品并尝试在datatable中更改它时,它会更改具有错误id的产品请参见前面的:
之前
之后
如你所见,他应该更改id为14的产品,并更改id为12的产品
更改了错误的产品
那么,你认为这里的问题是什么?
有没有办法在行中进行更改以及一些搜索过滤器?
我使用的是jsf2.2和primefaces8.0
对不起,我英语不好。

暂无答案!

目前还没有任何答案,快来回答吧!

相关问题