Как получить все строки в Grid View (который имеет AllowPaging = true) в DataTable?(Asp.net C#)

Я хочу получить данные из моего вида сетки в мою таблицу данных. проблема в том, что у моего вида сетки есть пейджер данных, и когда я хочу захватить данные в свою таблицу данных => ЭТО ПРОСТО ПОЛУЧИЛ СТРАНИЦУ ОДИН, поэтому это мои коды:

<asp:GridView ID="GVQuery" runat="server" AllowSorting="True" CssClass="query" GridLines="None" EmptyDataText="-"

                        AllowPaging="True" PagerSettings-Mode="Numeric" DataSourceID="SqlDS" AutoGenerateColumns="False">
                        <Columns>
                            <asp:BoundField DataField="Date" DataFormatString="{0:yyyy/MM/dd}" HeaderText="Date" SortExpression="Date" />
                            <asp:BoundField DataField="Time" DataFormatString="{0:t}" HeaderText="Time" SortExpression="Time" />
                            <asp:BoundField DataField="Balance" DataFormatString="{0:c0}" HeaderText="Balance" SortExpression="Balance">
                                <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" Wrap="False" />
                            </asp:BoundField>
                            <asp:BoundField DataField="Obligee" DataFormatString="{0:c0}" HeaderText="obligee" SortExpression="Obligee">
                                <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" Wrap="False" />
                            </asp:BoundField>
                            <asp:BoundField DataField="Debtor" DataFormatString="{0:c0}" HeaderText="Debtor" SortExpression="Debtor">
                                <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" Wrap="False" />
                            </asp:BoundField>
                            <asp:BoundField DataField="DocSerial" DataFormatString="" HeaderText="DocSerial" SortExpression="DocSerial" />
                            <asp:BoundField DataField="TransactionNo" DataFormatString="" HeaderText="TransNo" ConvertEmptyStringToNull="False" SortExpression="TransactionNo" />
                            <asp:BoundField DataField="TransactionType" DataFormatString="" HeaderText="TransType" SortExpression="TransactionType" />
                            <asp:BoundField DataField="PaymentType" HeaderText="PeymentType" SortExpression="PaymentType" />
                            <asp:BoundField DataField="BranchName" DataFormatString="" HeaderText="BranchName" SortExpression="BranchName" />
                            <asp:BoundField DataField="PayerName" DataFormatString="" HeaderText="Payer" SortExpression="PayerName" />
                            <asp:BoundField DataField="DocDescription" DataFormatString="{0:0c0}" HeaderText="DocDesc" SortExpression="DocDescription" />
                        </Columns>
                        <RowStyle CssClass="query-row" />
                        <AlternatingRowStyle CssClass="query-alternate-row" />
                        <PagerStyle CssClass="pager" />
                        <SortedAscendingHeaderStyle CssClass="sorted-asc-header" />
                        <SortedAscendingCellStyle CssClass="sorted-asc" BackColor="#12184a" ForeColor="#bddded" />
                        <SortedDescendingHeaderStyle CssClass="sorted-desc-header" />
                        <SortedDescendingCellStyle CssClass="sorted-desc" BackColor="#12184a" ForeColor="#bddded" />
                        <PagerSettings FirstPageText="Start" LastPageText="End" Position="Bottom" Mode="NumericFirstLast" PageButtonCount="40" />
                        <PagerStyle CssClass="pager" />
                        <EmptyDataTemplate>
                            <p>Nothing to Show</p>
                        </EmptyDataTemplate>
                    </asp:GridView>

И ЭТО КАК Я ПОЛУЧАЮ ДАННЫЕ В ТАБЛИЦУ ДАННЫХ:

DataTable dt = new DataTable();
        for (int i = 0; i < GVQuery.Columns.Count; i++)
        {
            dt.Columns.Add("column" + i.ToString());
            dt.Columns[i].Caption = GVQuery.Columns[i].HeaderText.ToString();
        }
        foreach (GridViewRow row in GVQuery.Rows)
        {
            DataRow dr = dt.NewRow();
            for (int j = 0; j < GVQuery.Columns.Count; j++)
            {
                dr["column" + j.ToString()] = row.Cells[j].Text;
            }

            dt.Rows.Add(dr);
        }
        for (int i = 0; i < dt.Columns.Count; i++)
        {
            dt.Columns[i].ColumnName = dt.Columns[i].Caption;
        }

0 ответов

Другие вопросы по тегам