簡體   English   中英

如何使用linq對網格視圖執行排序操作?

[英]how to perform sorting operation for a grid view using linq,?

我如何做到這一點(下面的代碼),但它引發以下錯誤。

錯誤:

 the type arguments for method 'System.Linq.Enumerable.OrderBy<TSource,TKey>(System.Collections.Generic.IEnumerable<TSource>,
     System.Func<TSource,TKey>, System.Collections.Generic.IComparer<TKey>)' 
    cannot be inferred from the usage.

碼:

gridview1.DataSource = (from bk in bookList
                                join ordr in bookOrders
                                on bk.BookID equals ordr.BookID
                                select new
                                {
                                    BookID = bk.BookID,
                                    BookNm = bk.BookNm,
                                    PaymentMode = ordr.PaymentMode
                                }).AsQueryable().OrderBy(e.SortExpression,e.SortDirection);

您正在將基於字符串的排序機制(GridView.Sorting事件)與Linq(基於lambda表達式的排序)混合在一起。

本文: 處理GridView.OnSorting()並使用LINQ動態創建排序表達式可以滿足您的要求

最后我做了以下

protected void gridview1_Sorting(object sender, GridViewSortEventArgs e)
        {
            int p = int.Parse(Session["p"].ToString());
            p++;
            Session["p"] = p;
            if (p % 2 == 0)
            {
                var A = from bk in bookList
                        join ordr in bookOrders
                        on bk.BookID equals ordr.BookID
                        select new
                        {
                            BookID = bk.BookID,
                            BookNm = bk.BookNm,
                            PaymentMode = ordr.PaymentMode
                        };


                gridview1.DataSource = A.OrderBy(x => x.BookID);
                gridview1.DataBind();

            }
            else
            {
                var A = from bk in bookList
                        join ordr in bookOrders
                        on bk.BookID equals ordr.BookID
                        select new
                        {
                            BookID = bk.BookID,
                            BookNm = bk.BookNm,
                            PaymentMode = ordr.PaymentMode
                        };


                gridview1.DataSource = A.OrderByDescending(x=>x.BookID);
                gridview1.DataBind();

            }



        }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM