C# Gridview-排序事件不起作用II

C# Gridview-排序事件不起作用II,c#,asp.net,sorting,gridview,C#,Asp.net,Sorting,Gridview,我有一个可编辑的GridView,试图将排序功能添加到指定的列。虽然我没有收到任何错误,并且我的编辑/插入/删除功能与预期一样,但我的排序方法不起作用。我能帮我弄点什么吗 设计: <asp:GridView ID="gvLogNotice" runat="server" AutoGenerateColumns="false" ShowFooter="false" OnRowCancelingEdit="gvLogNoti

我有一个可编辑的GridView,试图将排序功能添加到指定的列。虽然我没有收到任何错误,并且我的编辑/插入/删除功能与预期一样,但我的排序方法不起作用。我能帮我弄点什么吗

设计:

<asp:GridView ID="gvLogNotice" 
        runat="server" 
        AutoGenerateColumns="false" 
        ShowFooter="false"
        OnRowCancelingEdit="gvLogNotice_RowCancelingEdit"
        OnRowEditing="gvLogNotice_RowEditing" 
        OnRowUpdating="gvLogNotice_RowUpdating"
        EmptyDataText="There are no data records to display."
        DataKeyNames="LogNoticeID"
        AllowPaging="true"
        AllowSorting="true"
        OnSorting="gvLogNotice_sorting"
        Width="700px">
        <Columns>
            <asp:TemplateField HeaderText="Log No." Visible="false">
                <ItemTemplate>
                    <%#Eval("LogNoticeID")%>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="txtLogNoticeID" runat="server" Enabled="false" Text=' <%#Eval("LogNoticeID") %>'></asp:TextBox>
                </EditItemTemplate>
             </asp:TemplateField>
            <asp:TemplateField HeaderText="Log Date" SortExpression="DateLogged">
                <ItemTemplate>
                    <%#Eval("DateLogged")%>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="txtDateLogged" runat="server" Text=' <%#Eval("DateLogged") %>'></asp:TextBox>
                </EditItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField HeaderText="Log Description" HeaderStyle-Width="50px" sortexpression="LogNoticeDescript">
                <ItemTemplate>
                    <%#Eval("LogNoticeDescript")%>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="txtLogNoticeDescript" runat="server" Text=' <%#Eval("LogNoticeDescript") %>'></asp:TextBox>
                </EditItemTemplate>
           </asp:TemplateField>
           <asp:TemplateField HeaderText="Responsible Party" sortexpression="ResponsibleParty">
                <ItemTemplate>
                    <%#Eval("ResponsibleParty")%>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="txtResponsibleParty" runat="server" Text=' <%#Eval("ResponsibleParty") %>'></asp:TextBox>
                </EditItemTemplate>
          </asp:TemplateField>
             <asp:TemplateField HeaderText="Planned Date" SortExpression="PlannedDate" >
                <ItemTemplate>
                    <%#Eval("PlannedDate")%>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="txtPlannedDate" runat="server" Text=' <%#Eval("PlannedDate") %>'></asp:TextBox>
              </EditItemTemplate>
          </asp:TemplateField>
           <asp:TemplateField HeaderText="Case Number" SortExpression="CaseNumber">
                <ItemTemplate>
                    <%#Eval("CaseNumber")%>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="txtCaseNumber" runat="server" Text=' <%#Eval("CaseNumber") %>'></asp:TextBox>
              </EditItemTemplate>
          </asp:TemplateField>
             <asp:TemplateField HeaderText="Log Status" SortExpression="LogStatus">
                <ItemTemplate>
                    <%#Eval("LogStatus")%>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="txtLogStatus" runat="server" Text=' <%#Eval("LogStatus") %>'></asp:TextBox>
                </EditItemTemplate>
          </asp:TemplateField>
            <asp:TemplateField HeaderText="Edit">
                <ItemTemplate>
                    &nbsp;&nbsp;
                    <asp:ImageButton ID="ImageButton1" runat="server" ImageUrl="images/edit.png" Width="25"
                        Height="25" CommandName="Edit" />&nbsp;&nbsp;
                   <%-- <asp:ImageButton ID="ImageButton2" runat="server" ImageUrl="~/img/delete.png" CommandName="Delete"
                        OnClientClick="return confirm('Are you sure want to delete record?')" />--%>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:LinkButton ID="LinkButton1" runat="server" CommandName="Update">Update</asp:LinkButton>&nbsp;&nbsp;
                    <asp:LinkButton ID="LinkButton2" runat="server" CommandName="Cancel">Cancel</asp:LinkButton>
                </EditItemTemplate>
              </asp:TemplateField>
        </Columns>
    </asp:GridView>

您需要在LoadGrid中对表进行排序


编辑:对于框架,这是因为您没有排序。对于任何排序方向,您都在加载相同的数据表而不进行排序。我在这里得到一个错误(等号):void LoadGrid(string srtexpr=“”,string direc=“”)-错误是“不允许使用默认参数说明符”/“这不是ISO-C语言规范的一部分…在做了一些研究之后,看来,由于框架使用的是2.0,因此我必须使用方法调用操作重载。我理解正确吗?是的,你是对的!对于旧版本,必须重载该方法。我已经更新了我的答案。
protected void Page_Load(object sender, EventArgs e)
{
    lblmsg.Text = "";
    if (!Page.IsPostBack)
    {
        gvLogNotice.ShowFooter = false;
        //Load grid data using common method
        LoadGrid();
    }
}

//bind & load GV

void LoadGrid()
{
    sqlcmd = new SqlCommand("selectActiveLogs", sqlcon);
    sqlcmd.CommandType = CommandType.StoredProcedure;
    try
    {
        sqlcon.Open();
        da = new SqlDataAdapter(sqlcmd);
        dt.Clear();
        da.Fill(dt);
        gvLogNotice.DataSource = dt;
        gvLogNotice.DataBind();
    }
    catch (Exception ex)
    {
    }
    finally
    {
        sqlcon.Close();
    }
}

//sorting event

protected void gvLogNotice_sorting(object sender, GridViewSortEventArgs e)
{
    switch (e.SortExpression)
    {
        case "DateLogged":
            if (e.SortDirection == SortDirection.Ascending)
            {
                LoadGrid();
            }
            else
            {
                LoadGrid();
            }

            break;
    }
}
 void LoadGrid(string srtexpr, string direc)
{
    sqlcmd = new SqlCommand("selectActiveLogs", sqlcon);
    sqlcmd.CommandType = CommandType.StoredProcedure;
    try
    {
        sqlcon.Open();
        da = new SqlDataAdapter(sqlcmd);
        dt.Clear();
        da.Fill(dt);

        DataView dv = new DataView (dt);
        dv.Sort = srtexpr + " " + direc;
        gvLogNotice.DataSource = dv;
        gvLogNotice.DataBind();

    }
    catch (Exception ex)
    {

    }
    finally
    {
        sqlcon.Close();
    }
}
protected void gvLogNotice_sorting(object sender, GridViewSortEventArgs e)
{
    switch (e.SortExpression)
    {
        case "DateLogged":
            if (e.SortDirection == SortDirection.Ascending)
            {
               LoadGrid("DateLogged", "ASC");
            }
            else
            {
                LoadGrid();
            }

            break;

       }

}