سلام
من یک برنامه تولید لایه business نوشتم از کد شما هم استفاده کردم با اجازتون یه تغییر کوچیک دادم توش خواستم اینجا هم بذارم که اگر کسی خواست استفاده کنه
و برای فراخوانی هم اینطور استفاده کردم
من یک برنامه تولید لایه business نوشتم از کد شما هم استفاده کردم با اجازتون یه تغییر کوچیک دادم توش خواستم اینجا هم بذارم که اگر کسی خواست استفاده کنه
private static IQueryable<T> PagedResult<T, TResult>(IQueryable<T> query, int pageNum, int pageSize, Expression<Func<T, TResult>> orderByProperty, bool isAscendingOrder, out int rowsCount, Expression<Func<T, bool>> whereClause = null) { if (pageSize <= 0) pageSize = 20; //مجموع ردیفهای به دست آمده rowsCount = query.Count(); // اگر شماره صفحه کوچکتر از 0 بود صفحه اول نشان داده شود if (rowsCount <= pageSize || pageNum <= 0) pageNum = 1; // محاسبه ردیف هایی که نسبت به سایز صفحه باید از آنها گذشت int excludedRows = (pageNum - 1) * pageSize; query = isAscendingOrder ? query.OrderBy(orderByProperty) : query.OrderByDescending(orderByProperty); //جستجو را در صورت لزوم انجام میدهد query = whereClause == null ? query : query.Where(whereClause); // ردشدن از ردیفهای اضافی و دریافت ردیفهای مورد نظر برای صفحه مربوطه return query.Skip(excludedRows).Take(pageSize); }
و برای فراخوانی هم اینطور استفاده کردم
public static List<t_Prodcts> GetPaging(int currentPage, int pageSize, out int count, Expression<Func<t_Prodcts, bool>> search = null) { using (var db = new asusIranDBConnection()) { return PagedResult(db.t_Prodcts, currentPage, pageSize, o => true, false, out count, search).ToList(); } }