DataTable的數據分頁


在有些需要展示數據的時候,如果數據比較多的話  就需要用到分頁來展示,這樣才不會顯得頁面繁冗。

所以在此記錄獲取DataTable分頁的數據的方法:

        /// <summary>
        /// Select 頁面 數據分頁
        /// </summary>
        /// <param name="dt">數據源</param>
        /// <param name="PageIndex">第幾頁</param>
        /// <param name="PageSize">每頁多少條</param>
        /// <returns></returns>
        public static DataTable getPageToDataTable(DataTable dt, int PageIndex, int PageSize)
        {
            if (PageIndex == 0)
                return dt;//0頁代表每頁數據,直接返回

            if (dt == null)
            {
                DataTable table = new DataTable();
                return table ;
            }

            DataTable newdt = dt.Copy();
            newdt.Clear();//copy dt的框架

            int rowbegin = (PageIndex - 1) * PageSize;
            int rowend = PageIndex * PageSize;//要展示的數據條數

            if (rowbegin >= dt.Rows.Count)
                return newdt;//源數據記錄數小於等於要顯示的記錄,直接返回dt

            if (rowend > dt.Rows.Count)
                rowend = dt.Rows.Count;
            for (int i = rowbegin; i <= rowend - 1; i++)
            {
                DataRow newdr = newdt.NewRow();
                DataRow dr = dt.Rows[i];
                foreach (DataColumn column in dt.Columns)
                {
                    newdr[column.ColumnName] = dr[column.ColumnName];
                }
                newdt.Rows.Add(newdr);
            }
            return newdt;
        }

上面的代碼是應用在已經查詢出來的數據放在datatable中,然后對datatable進行數據篩選。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM