欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#將DataTable轉(zhuǎn)換成list的方法

 更新時間:2015年01月21日 14:43:04   投稿:shichen2014  
這篇文章主要介紹了C#將DataTable轉(zhuǎn)換成list的方法,實例分析了DataTable轉(zhuǎn)換成list及數(shù)據(jù)分頁的技巧,需要的朋友可以參考下

本文實例講述了C#將DataTable轉(zhuǎn)換成list及數(shù)據(jù)分頁的方法。分享給大家供大家參考。具體如下:

復制代碼 代碼如下:
/// <summary> 
 /// 酒店評論列表-分頁 
/// </summary> 
/// <param name="userId"></param> 
/// <param name="pageIndex">當前頁</param> 
/// <param name="pageCount">總頁數(shù)</param> 
/// <returns></returns> 
 public static List<CommentInfo> GetHotelCommentList(int userId, int pageIndex, out int pageCount) 
 { 
     var list = new List<CommentInfo>(); 
     pageCount = 0; 
     try 
     { 
         //查詢酒店ID,名字,圖片,用戶ID,用戶評論 
         string sql = string.Format( @"select hotels.hid,hotels.hotelName,hotels.images,hotelorder.UserID,user_HotelComment.comment from hotels with(nolock) join hotelorder with(nolock) join user_HotelComment  
telorder.UserID=user_HotelComment.userID on hotels.hid=hotelorder.HotelID where hotelorder.UserID={0}", userId); 
         DataTable dt = SQLHelper.Get_DataTable(sql, SQLHelper.GetCon(), null); 
         if (dt != null && dt.Rows.Count > 0) 
         { 
             list = (from p in dt.AsEnumerable()  //這個list是查出全部的用戶評論 
                     select new CommentInfo 
                     { 
                         Id = p.Field<int>("hid"), //p.Filed<int>("Id") 其實就是獲取DataRow中ID列。即:row["ID"] 
                         HotelImages = p.Field<string>("images"), 
                         HotelName = p.Field<string>("hotelName"), 
                         Comment = p.Field<string>("comment") 
                     }).ToList(); //將這個集合轉(zhuǎn)換成list 
             int pageSize = 10; //每頁顯示十條數(shù)據(jù) 
 
             //獲取總頁數(shù) 
             pageCount = list.Count % pageSize == 0 ? ((list.Count - pageSize >= 0 ? (list.Count / pageSize) : (list.Count == 0 ? 0 : 1))) : list.Count / pageSize + 1; 
 
             //這個list 就是取到10條數(shù)據(jù) 
             //Skip跳過序列中指定數(shù)量的元素,然后返回剩余的元素。 
             //Take序列的開頭返回指定數(shù)量的連續(xù)元素。 
             list = list.Skip(pageSize * (pageIndex - 1)).Take(pageSize).ToList(); //假設(shè)當前頁為第三頁。這么這里就是跳過 10*(3-1) 即跳過20條數(shù)據(jù),Take(pageSize)的意思是:取10條數(shù)據(jù),既然前面已經(jīng)跳過前20條數(shù)據(jù)了,那么這里就是從21條開始,取10條咯 
         } 
     } 
     catch (Exception ex) 
     { 
         // write log here 
     } 
     return list; 
}

將一個DataTable轉(zhuǎn)換成一個List
首先定義一個接收DataTable字段列的類 。類的字段與DataTable的列字段一致

復制代碼 代碼如下:
using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
 
namespace WebApplication1 

    /// <summary> 
    /// 用戶信息 
    /// </summary> 
    public class User 
    { 
        public int Id { get; set; } 
 
        public string UserName { get; set; } 
 
        public int Age { get; set; } 
 
        public int Gender { get; set; } 
    } 
}

復制代碼 代碼如下:
using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
using JSON.Controllers; 
using System.Data; 
 
namespace WebApplication1 

    public class Class1 
    { 
        /// <summary> 
        /// 將DataTable轉(zhuǎn)換成一個list 
        /// </summary> 
        /// <returns>返回一個List<User>對象</returns> 
        public List<User> TableToList() 
        { 
            string sql = "select  * from T_User"; //T_User表里總共有 id,UserName,Age,Gender四列 
            DataTable dt= SqlHelper.ExecuteDataTable(sql,null); 
            var list = new List<User>(); //創(chuàng)建一個List<User>的實例 
            if (dt != null && dt.Rows.Count > 0) 
            { 
                //AsEnumerable():返回一個IEnumerable<T> 對象,其泛型參數(shù) T 為 System.Data.DataRow。 
                list = (from p in dt.AsEnumerable() 
                        select new User  //new一個User對象 
                        { 
                            Id = p.Field<int>("id"),//p.Filed<int>("id") 其實就是獲取DataRow中ID列。即:row["ID"] 然后將它賦值給User類的Id字段。 
                            UserName = p.Field<string>("UserName"), 
                            Age = p.Field<int>("Age"), 
                            Gender = p.Field<int>("Gender") 
                        }).ToList(); //將這個User類對象轉(zhuǎn)換成list 
            } 
            int dataCount = list.Count; // 總的數(shù)據(jù)條數(shù)。 
            int pageSize=10;//每頁顯示多少條數(shù)據(jù)。             
            int pageCount; //總頁數(shù)。 
            int currentPage=3;//當前頁。--這里假設(shè)當前頁為第3頁。 
            pageCount = dataCount % pageSize == 0 ? (dataCount < pageSize ? (dataCount==0?0:1): (dataCount / pageSize)) : (dataCount / pageSize + 1); 

     //這個list 就是取到10條數(shù)據(jù)   
            //Skip跳過序列中指定數(shù)量的元素,然后返回剩余的元素。   
            //Take序列的開頭返回指定數(shù)量的連續(xù)元素。   
            list = list.Skip(pageSize * (currentPage - 1)).Take(pageSize).ToList(); //假設(shè)當前頁為第3頁。這么這里就是跳過 10*(3-1) 即跳過20條數(shù)據(jù),Take(pageSize)的意思是:取10條數(shù)據(jù),既然前面已經(jīng)跳過前20條數(shù)據(jù)了,那么這里就是從21條開始,取10條咯   
            return list;  
        }         
    } 
}

希望本文所述對大家的C#程序設(shè)計有所幫助。

相關(guān)文章

  • C#中ListView用法實例

    C#中ListView用法實例

    我們經(jīng)常會在應(yīng)用程序中使用列表的形式來展現(xiàn)一些內(nèi)容,所以學好ListView是非常必需的,下面這篇文章主要給大家介紹了關(guān)于C#中ListView用法的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • C#實現(xiàn)顯示CPU使用率與內(nèi)存使用率

    C#實現(xiàn)顯示CPU使用率與內(nèi)存使用率

    這篇文章主要為大家詳細介紹了如何利用C#實現(xiàn)顯示CPU使用率與內(nèi)存使用率,文中的示例代碼講解詳細,對我們學習C#有一定的幫助,感興趣的小伙伴可以了解一下
    2022-12-12
  • C#序列化與反序列化實例

    C#序列化與反序列化實例

    這篇文章主要介紹了C#序列化與反序列化的實現(xiàn)方法,實例分析了序列化與反序列化的原理與實現(xiàn)技巧,需要的朋友可以參考下
    2015-01-01
  • C#實現(xiàn)壓縮圖片為可控制的JPEG格式

    C#實現(xiàn)壓縮圖片為可控制的JPEG格式

    這篇文章主要為大家詳細介紹了使用C#實現(xiàn)將圖片壓縮為質(zhì)量可自己控制的JPEG的幾種方式,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2024-01-01
  • C#設(shè)計模式之Strategy策略模式解決007大破密碼危機問題示例

    C#設(shè)計模式之Strategy策略模式解決007大破密碼危機問題示例

    這篇文章主要介紹了C#設(shè)計模式之Strategy策略模式解決007大破密碼危機問題,簡單描述了策略模式的定義并結(jié)合加密解密算法實例分析了C#策略模式的具體使用方法,需要的朋友可以參考下
    2017-09-09
  • C#多線程編程之使用ReaderWriterLock類實現(xiàn)多用戶讀與單用戶寫同步的方法

    C#多線程編程之使用ReaderWriterLock類實現(xiàn)多用戶讀與單用戶寫同步的方法

    這篇文章主要介紹了C#多線程編程之使用ReaderWriterLock類實現(xiàn)多用戶讀與單用戶寫同步的方法,涉及C#多線程操作讀寫鎖定的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-11-11
  • C# 文件安全管理需要注意的

    C# 文件安全管理需要注意的

    這篇文章主要介紹了C# 文件安全管理需要注意的,幫助大家更好的理解和學習使用c#,感興趣的朋友可以了解下
    2021-03-03
  • Unity shader實現(xiàn)消融效果

    Unity shader實現(xiàn)消融效果

    這篇文章主要為大家詳細介紹了Unity shader實現(xiàn)消融效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • c#入門之循環(huán)語句使用詳解(for循環(huán)、do/while)

    c#入門之循環(huán)語句使用詳解(for循環(huán)、do/while)

    這篇文章主要介紹了c#入門之循環(huán)語句使用詳解,有for循環(huán)和do/while的示例,需要的朋友可以參考下
    2014-04-04
  • 對c#中委托的理解

    對c#中委托的理解

    本篇文章,小編將為大家介紹關(guān)于對c#中委托的理解,有需要的朋友可以參考一下
    2013-04-04

最新評論