GridHyperLinkColumn/GridTemplateColumn
To enable sorting for GridHyperLinkColumn and GridTemplateColumn, you need to set appropriate SortExpression values for those columns.
When using GridHyperLinkColumn, the SortExpression value should match the DataTextField property of the column.
When using GridTemplateColumn, the SortExpression value should match the data field you want to sort on (typically the field a control in the template is bound to).
<telerik:RadGrid RenderMode="Lightweight" ID="RadGrid1" runat="server" DataSourceID="SqlDataSource1" AllowSorting="True"
Width="400px">
<MasterTableView AutoGenerateColumns="false" AllowSorting="true">
<Columns>
<telerik:GridHyperLinkColumn DataTextField="Country" NavigateUrl="https://www.telerik.com"
HeaderText="Country" SortExpression="Country" />
<telerik:GridTemplateColumn UniqueName="TemplateColumn" HeaderText="City" SortExpression="City">
<ItemTemplate>
<%# Eval("City") %>
</ItemTemplate>
</telerik:GridTemplateColumn>
</Columns>
</MasterTableView>
</telerik:RadGrid>
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:NorthwindConnectionString %>"
SelectCommand="SELECT TOP 10 [Country], [City] FROM [Customers]">
</asp:SqlDataSource>
You can add a sort button to a template in the grid. When adding a sort button, set the CommandName property to "Sort" and the sort expression as the CommandArgument for the button. RadGrid can then handle the sorting automatically when the user clicks the button.
<telerik:GridTemplateColumn SortExpression="CompanyName">
<HeaderTemplate>
<asp:Button id="Button1" runat="server"
Text="GridTemplateColumn"
Title="Sort by CompanyName"
CommandName='Sort'
CommandArgument='CompanyName' />
</HeaderTemplate>
...