Set the SortExpression property for each column. For example, it SortExpression="Column1"means sort by Column1, SortExpression="Column2"means sort by Column2, etc. Here's what the aspx code looks like:
<asp:GridView ID="gvResults" runat="server" Width="100%" AllowSorting="True" OnSorting="gvResults_Sorting" AutoGenerateColumns="False" CssClass="tblBrowse">
<Columns>
<asp:BoundField DataField="Column1" SortExpression="Column1" />
<asp:BoundField DataField="Column2" SortExpression="Column2" />
</Columns>
</asp:GridView>
We need to save the last sort expression and the sort direction between postbacks, so these two properties are needed:
private string SortExpression
{
get
{
return ViewState["SortExpression"] == null ? string.Empty : ViewState["SortExpression"].ToString();
}
set
{
ViewState["SortExpression"] = value;
}
}
private string SortDirection
{
get
{
return ViewState["SortDirection"] == null ? string.Empty : ViewState["SortDirection"].ToString();
}
set
{
ViewState["SortDirection"] = value;
}
}
This is the method to get the following sort direction:
private string GetSortDirection(string sortExpression)
{
if (sortExpression == this.SortExpression)
{
if (this.SortDirection == "ASC")
{
return "DESC";
}
else
{
return "ASC";
}
}
else
{
return "ASC";
}
}
, gvResults_Sorting:
protected void gvResults_Sorting(object sender, GridViewSortEventArgs e)
{
try
{
DataTable dtSortTable = gvResults.DataSource as DataTable;
if (dtSortTable != null)
{
string sortDirection = GetSortDirection(e.SortExpression);
DataView dvSortedView = new DataView(dtSortTable);
dvSortedView.Sort = e.SortExpression + " " + sortDirection;
gvResults.DataSource = dvSortedView;
gvResults.DataBind();
this.SortExpression = e.SortExpression;
this.SortDirection = sortDirection;
}
}
catch (Exception ex)
{
ExceptionHandling.NETException(ex, constPageID, constIsSiteSpecific);
}
}