У меня есть gridview, и его источником данных являются операторы linq to sql:
var query = from user in dataContext.tbl_files
select new { user.File_Name, user.Upload_Time, user.Uploaded_By };
GridView1.DataSource = query.ToList();
GridView1.DataBind();
Я пытаюсь реализовать функцию сортировки gridview:
public void GridView1_Sorting(object sender, GridViewSortEventArgs e)
{
string previousSortExpression = (string)ViewState["SortDirection"];
string sortExpression = e.SortExpression;
SortDirection sortDirection = e.SortDirection;
if (sortExpression.Equals(previousSortExpression))
{
sortDirection = SortDirection.Descending;
ViewState["SortDirection"] = string.Empty;
}
else
ViewState["SortDirection"] = sortExpression;
string direction = sortDirection == SortDirection.Ascending ? "ASC" : "DESC";
e.SortExpression = string.Format("it.{0} {1}", e.SortExpression, direction);
DataTable dataTable = (DataTable)GridView1.DataSource; // here returns null!
if (dataTable != null)
{
DataView dataView = new DataView(dataTable);
dataView.Sort = e.SortExpression ;
GridView1.DataSource = dataView;
GridView1.DataBind();
}
}
Но " DataTable dataTable = (DataTable)GridView1.DataSource; "
строка возвращает ноль, однако количество источника данных равно 4. Я получил эту ошибку:
{"Невозможно привести объект типа 'System.Collections.Generic.List 1[<>f__AnonymousType0
3 [System.String, System.Nullable`1 [System.DateTime], System.String]] 'для ввода' System.Data.DataTable '. "}
Как мне отсортировать сетку и исправить ошибку?Спасибо ..