当我有一个单独的方法来搜索数据表时,Primefaces 数据表更改项目的 id 错误 (onrowedit)

如何解决当我有一个单独的方法来搜索数据表时,Primefaces 数据表更改项目的 id 错误 (onrowedit)

我有一个从数据库中获取产品列表的 bean,我可以在 onRowEdit 中正常更改它,但是当我在 beanProd.searchProd() 表单中搜索 part 方法时,它会用相关产品填充数据表当我更改其中的一些时, 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 + "]";
    }

    
    

    
    
    

}

抱歉没有详细说明,这是我在这里的第一篇文章,让我们来看细节示例 all produtcts in datatable

以下是数据库中使用@PostConstruct注解填充datatable init()方法的产品

当我用 CREME 这个词搜索左边的表单时,他调用 searchProd 方法 q 用包含 CREME 这个词的产品填充数据表

search form populate datatable search string

如您所见,数据表仅填充了包含 CREAM 一词的产品

在搜索之前,我可以直接在数据表中更改产品,通常它会在数据库中正确更改产品,但是当我搜索包含某个单词的产品并尝试在数据表中更改它时,它会更改之前看到的 ID 错误的产品:

before

after

如您所见,他应该更改 ID 为 14 的产品,而他更改 ID 为 12 的产品

wrong product changed

那么,您认为这里的问题是什么?

有没有办法在行中进行更改以及一些搜索过滤器?

我使用的是 JSF 2.2 和 Primefaces 8.0

抱歉我的英语不好。

解决方法

如果您的方法之一更新了产品列表,但不更新表单(视图),则可能会发生这种情况。

调试模式下启动您的应用,并在 #{beanProd.produtos} 的 setter 上设置断点,并查找您的列表何时更新。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-