2

我正在尝试在 Ext.js 网格中实现自定义分页,我需要根据页面大小获取表的总记录和记录。我正在为此使用编译查询。

但我只想给一个数据库命中。

    List<MyTable> .GetRecordsById(Int32 ID, Int32 start, Int32 limit)
    {
        return CompliedGetRecordsById_CustomPaging(_dbNavigation, ID, start, limit).ToList();
    }

    /// <summary>
    /// Complied query for retrieving manage tasks Custom Paging
    /// </summary>
    public static readonly Func<SomeEntities, Int32,Int32, Int32, IQueryable<MyTable>> CompliedGetTaskByProjectId_CustomPaging =
        CompiledQuery.Compile<SomeEntities, Int32, Int32, Int32, IQueryable<MyTable>>((dbNavigation, ID, start, limit) =>
                                        dbNavigation.SiteTasksMappings.Include("TaskMaster")
                                        .Where(x=> x.myTableID == ID && x.STMIsActive == 1).OrderBy(x=>x.STMID).Skip(start).Take(limit));

这只会根据参数给出记录,我想从这里返回总记录和自定义记录数

4

1 回答 1

3

我猜你正在使用 MS-SQL Server?好吧,这是无法做到的。您至少需要一个子选择来计数。但这会导致您获得一种丑陋的匿名结果类型。

我建议您为此类表编写一个视图,该视图会添加一个总计数字段。请注意,MS SQL Server 支持仅针对一张表的视图的写入操作。如果您更简单地编写一些存储过程并将它们分配给视图的实体模型。

于 2013-11-27T07:06:42.423 回答