qtvb1987
qtvb1987
采纳率12.5%
2019-08-30 15:36 阅读 234

jqgrid linq 分页查询问题

比如我SortCode 字段为null 排序,返回数据总数对的,但是分页数据显示会有重复行,换个其他字段就分页数据显示就对的,不知道啥问题。

不像sql rownumber函数 order by 字段必需唯一不重复

jqgrid 前台页面通过 sortname: 'SortCode', sortorder: 'asc',

字段传到后台排序

底层方法
public IEnumerable FindList(Expression> condition, string orderField, bool isAsc, int pageSize, int pageIndex, out int total) where T : class,new()
{
using (var dbConnection = Connection)
{
string[] _orderField = orderField.Split(',');
var dataLinq = new SQLinq().Where(condition);

            foreach (string item in _orderField)
            {
                var parameter = Expression.Parameter(typeof(T), "t");
                var property = typeof(T).GetProperty(item);
                var propertyAccess = Expression.MakeMemberAccess(parameter, property);
                Expression<Func<T, object>> orderBy = t => propertyAccess;
                dataLinq.OrderByExpressions.Add(new SQLinq<T>.OrderByExpression { Ascending = isAsc, Expression = orderBy });
            }
            var dataQuery = dbConnection.Query<T>(dataLinq);
            total = dataQuery.Count();
            var data = dataQuery.Skip<T>(pageSize * (pageIndex - 1)).Take<T>(pageSize).AsQueryable();
            return data.ToList();
        }
    }
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

1条回答 默认 最新

  • caozhy 从今以后生命中的每一秒都属于我爱的人 2019-08-30 16:33

    排序的字段本身是否有重复,将
    dataLinq = new SQLinq().Where(condition);
    写成dataLinq = new SQLinq().Where(condition).AsEnumerable();
    看看是不是可以

    点赞 评论 复制链接分享

相关推荐