我有一个带有100,000条记录的表,并且我有一个方法(使用实体框架)来检索10条记录,我给它跳过多少条记录以获取下10条记录。

List<Item> GetRecords(int skip = 0);


我将前10条记录加载到列表中,并将其设置为UltraGrid的数据源,当滚动到达底部或接近底部时,如何调用该方法来获取接下来的10条记录并将其添加到UltraGrid中?

最佳答案

我有您需要的解决方案。希望这对您有帮助。

首先,创建一个名为“ test”的Windows窗体(例如)。
在表单中添加一个UltraGrid。



检查以下代码:

   public partial class test : Form
   {
    DataTable dtSource = new DataTable();
    int takecount = 50;
    int skipcount = 0;
    DataTable dtResult;

    // CONSTRUCTOR
    public test()
    {
        InitializeComponent();

        // Fill Dummy data here as datasource...

        dtSource.Columns.Add("SNo", typeof(int));
        dtSource.Columns.Add("Name", typeof(string));
        dtSource.Columns.Add("Address", typeof(string));
        int i = 1;
        while (i <= 500)
        {
            dtSource.Rows.Add(new object[] { i, "Name: " + i, "Address " + i });
            i++;
        }
        dtResult = dtSource.Copy();
        dtResult.Clear();
    }

    // ON FORM LOAD FUNCTION CALL
    private void test_Load(object sender, EventArgs e)
    {
        ultraGrid1.DataSource = dt_takeCount();
        ultraGrid1.DataBind();


    }

    private DataTable dt_takeCount()
    {
        if (dtSource.Rows.Count - skipcount <= takecount)
        {
            takecount = dtSource.Rows.Count - skipcount;
        }
        foreach (var item in dtSource.AsEnumerable().Skip(skipcount).Take(takecount))
        {
            dtResult.Rows.Add(new object[] { item.Field<int>("SNo"), item.Field<string>("Name"), item.Field<string>("Address") });
        }
        if (dtSource.Rows.Count - skipcount >= takecount)
        {
            skipcount += takecount;
        }
        return dtResult;
    }

    // EVENT FIRED WHEN ON AFTERROWREGIONSCROLL
    private void ultraGrid1_AfterRowRegionScroll(object sender, Infragistics.Win.UltraWinGrid.RowScrollRegionEventArgs e)
    {
        int _pos = e.RowScrollRegion.ScrollPosition;
        if (ultraGrid1.Rows.Count - _pos < takecount)
        {
            dt_takeCount();
        }
    }
}


上面的代码是所有的工作..
->“ ultraGrid1_AfterRowRegionScroll”函数是“ AfterRowRegionScroll”事件函数

->但是请确保选择“ takecount”时,它会生成滚动条,
->当您运行以上代码时...滚动时该行将更新50,直到第500行..因为它是最后一行。

10-04 09:59