asp.net gridview分页直到刷新才显示

时间:2014-09-19 07:56:20

标签: c# asp.net gridview pagination

我在页面上有一个DataGridView。当我打电话给那个页面时,整个列表来了我决定将分页添加到GridView

 <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataKeyNames="id" OnRowDeleting="GridView1_Del" OnSelectedIndexChanging="GridView1_Sel"  OnPageIndexChanging="GridView1_PageIndexChanging">
            <Columns>
                <asp:BoundField DataField="id" HeaderText="Id" SortExpression="id" Visible="false" />
                <asp:BoundField DataField="name" HeaderText="Name" SortExpression="name" />
                <asp:BoundField DataField="author" HeaderText="Author" SortExpression="author" />
                <asp:BoundField DataField="active" HeaderText="Active" SortExpression="active" />
                <asp:CommandField HeaderText="Delete" SelectText="Delete"  ShowDeleteButton="True" ButtonType="Button" />
            </Columns>
        </asp:GridView>



//Page_Load()
gridFill();
GridView1.AllowPaging = true;
GridView1.PageSize = 10;

gridFill()方法填充GridView

public void gridFill()
{
    conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:/inetpub/example.com/db/db.mdb");
    sql = "SELECT  id, name, author, active, FROM [table]";
    dt = new DataTable();

    try
    {
        if (conn.State != ConnectionState.Open) conn.Open();
        comm= new OleDbCommand(sql, conn);
        da= new OleDbDataAdapter(comm);

        da.Fill(dt);

        if (dt.Rows.Count > 0)
        {
            GridView1.DataSource = dt;
            GridView1.DataBind();
        }
    }

    catch (System.Data.OleDb.OleDbException ex)
    {
        string msg = "Error: ";
        msg += ex.Message;
        throw new Exception(msg);
    }

    finally
    {
        conn.Close();
    }
}

当我调用页面时,它仍会立即获取所有行。此外,如果我点击11或更晚(因为我将分页限制为10行)删除行我得到索引错误。

所以我添加了另一个标记为'Refresh'的Button,再次调用gridFill()方法。然后分页变得有效。

GridView第一次不进行分页的原因是什么?

1 个答案:

答案 0 :(得分:1)

如果我改变了行的顺序

//Page_Load()
gridFill();
GridView1.AllowPaging = true;
GridView1.PageSize = 10;

//Page_Load()
GridView1.AllowPaging = true;
GridView1.PageSize = 10;
gridFill();

它有效。我无法相信

相关问题