0

レコードを削除しているコマンド リンクをクリックすると、データ テーブルで JSF/primefaces ajax 更新を実行しようとしています。コマンド リンクをクリックすると、データベースは更新されますが、更新を使用してもデータテーブルは更新されません。 ="@form" 属性。この問題を解決する方法に関するガイダンスは非常に役立ちます。

state、region のようないくつかの列を含む行編集可能なデータテーブルである私の JSF コード スニペットは以下のとおりです。

<h:form id="lpcForm">

    <div id="content">
        <p:commandLink id="cmdLinkDelete" value="Delete" ajax="true"
            action="#{lpcBean.deleteRecords}" update="lpcDataTable" />

        <p:dataTable var="lpcData" id="lpcDataTable" widgetVar="lpcTable"
            value="#{lpcBean.lpcIdList}" selection="#{lpcBean.selectedRows}"
            editable="true" scrollable="true" scrollWidth="1110"
            scrollHeight="330" styleClass="datatable" resizableColumns="true">
            <p:ajax event="rowEdit" listener="#{lpcBean.onEdit}" />
            <p:ajax event="rowEditCancel" listener="#{lpcBean.onCancel}" />

            <p:column selectionMode="multiple" style="width:15px" />

            <p:column headerText="LPC ID" style="width:20px">
                <h:outputText value="#{lpcData.LPCID}" />
            </p:column>

            <p:column headerText="Region" style="width:40px">
                <p:cellEditor>
                    <f:facet name="output">
                        <h:outputText value="#{lpcData.region}" />
                    </f:facet>
                    <f:facet name="input">
                        <h:selectOneMenu value="#{lpcData.region}">
                            <f:selectItems value="#{lpcBean.regions}" />
                        </h:selectOneMenu>
                    </f:facet>
                </p:cellEditor>
            </p:column>


            <p:column headerText="State" style="width:15px">
                <p:cellEditor>
                    <f:facet name="output">
                        <h:outputText value="#{lpcData.homeState}" />
                    </f:facet>
                    <f:facet name="input">
                        <h:selectOneMenu value="#{lpcData.homeState}">
                            <f:selectItems value="#{lpcBean.mainStates}" />
                        </h:selectOneMenu>
                    </f:facet>
                </p:cellEditor>
            </p:column>

            .
            .
            .

            <p:column style="width:10px">
                <p:rowEditor />
            </p:column>

        </p:dataTable>

    </div>
</h:form>

変数 lpcIdList は、DataModelを実装するクラスの型です。

以下は、deleteRecords メソッドを含むマネージド Bean のスニペットです。マネージド BeanRequestScopedです。

public String deleteRecords()
{
    System.out.println("inside delete records");
    System.out.println("Selected rows length:"+ selectedRows.length);
    for(LPC itemSelect:selectedRows)
    {
        String lpcId=itemSelect.getLPCID();
        JdbcConnection jdbcConnection=new JdbcConnection();
        connection=jdbcConnection.getJdbcConnection();
        try{
            preparedStmt=connection.prepareStatement("delete from LPC where LPCID=?");
            preparedStmt.setString(1, lpcId);
            preparedStmt.execute();

        }
        catch(Exception e)
        {
            e.printStackTrace();
        }


    }
    return null;


}

変数selectedRowsはデータテーブルの選択属性です

データベースからデータを取得する getLpcFields メソッド

public void getLpcFields() {

    try
    {

        JdbcConnection jdbcConnection =new JdbcConnection();
        connection=jdbcConnection.getJdbcConnection();
        System.out.println("connected to the database");

        selectStmt1 = connection.createStatement();
        ResultSet rs1 = selectStmt1.executeQuery("select * from LPC order by LPCID");


        while(rs1.next()){


            lpcItems.add(new LPC(rs1.getString("LPCID"),rs1.getString("Name_First"),rs1.getString("Name_Last"),rs1.getString("Email_Address"),rs1.getString("Region"),
                    rs1.getString("HomeState"),rs1.getString("ProfitCenter"),rs1.getString("Active_LPC"),rs1.getString("Name")));
        }
        selectStmt2=connection.createStatement();
        ResultSet rs2=selectStmt2.executeQuery("Select * from Tbl_state");


        while(rs2.next())
        {
            mainStates.add(rs2.getString("State"));

        }
        selectStmt3=connection.createStatement();
        ResultSet rs3=selectStmt3.executeQuery("Select * from Tbl_Regional_Managers");

        while(rs3.next())
        {
            regions.add(rs3.getString("Location"));
        }
        selectStmt4=connection.createStatement();
        ResultSet rs4=selectStmt4.executeQuery("Select * from YesNo order by YesNo_Key desc");



        while(rs4.next())
        {
            activeLpcs.add(rs4.getString("Description"));
        }


    }
    catch (Exception e)
    {

        e.printStackTrace();
    }
    finally
    {
        try {

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

    }


}
4

1 に答える 1

0

Xtreme Biker の反応は正しいです (h/t)。lpcIdList でラップされたデータをクリアする必要があります。コードの実装方法に応じて、新しいリストを作成するか、既存のリストからアイテムを削除する必要があります。setWrappedData()次に、のメソッドを使用できますListDataModel

于 2013-09-04T17:33:39.550 に答える