C#将DataTable转换成list的方法

 更新时间:2015年01月21日 14:43:04   投稿:shichen2014  
这篇文章主要介绍了C#将DataTable转换成list的方法,实例分析了DataTable转换成list及数据分页的技巧,需要的朋友可以参考下

本文实例讲述了C#将DataTable转换成list及数据分页的方法。分享给大家供大家参考。具体如下:

复制代码 代码如下:
/// <summary> 
 /// 酒店评论列表-分页 
/// </summary> 
/// <param name="userId"></param> 
/// <param name="pageIndex">当前页</param> 
/// <param name="pageCount">总页数</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(); //将这个集合转换成list 
             int pageSize = 10; //每页显示十条数据 
 
             //获取总页数 
             pageCount = list.Count % pageSize == 0 ? ((list.Count - pageSize >= 0 ? (list.Count / pageSize) : (list.Count == 0 ? 0 : 1))) : list.Count / pageSize + 1; 
 
             //这个list 就是取到10条数据 
             //Skip跳过序列中指定数量的元素,然后返回剩余的元素。 
             //Take序列的开头返回指定数量的连续元素。 
             list = list.Skip(pageSize * (pageIndex - 1)).Take(pageSize).ToList(); //假设当前页为第三页。这么这里就是跳过 10*(3-1) 即跳过20条数据,Take(pageSize)的意思是:取10条数据,既然前面已经跳过前20条数据了,那么这里就是从21条开始,取10条咯 
         } 
     } 
     catch (Exception ex) 
     { 
         // write log here 
     } 
     return list; 
}

将一个DataTable转换成一个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转换成一个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>(); //创建一个List<User>的实例 
            if (dt != null && dt.Rows.Count > 0) 
            { 
                //AsEnumerable():返回一个IEnumerable<T> 对象,其泛型参数 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类对象转换成list 
            } 
            int dataCount = list.Count; // 总的数据条数。 
            int pageSize=10;//每页显示多少条数据。             
            int pageCount; //总页数。 
            int currentPage=3;//当前页。--这里假设当前页为第3页。 
            pageCount = dataCount % pageSize == 0 ? (dataCount < pageSize ? (dataCount==0?0:1): (dataCount / pageSize)) : (dataCount / pageSize + 1); 

     //这个list 就是取到10条数据   
            //Skip跳过序列中指定数量的元素,然后返回剩余的元素。   
            //Take序列的开头返回指定数量的连续元素。   
            list = list.Skip(pageSize * (currentPage - 1)).Take(pageSize).ToList(); //假设当前页为第3页。这么这里就是跳过 10*(3-1) 即跳过20条数据,Take(pageSize)的意思是:取10条数据,既然前面已经跳过前20条数据了,那么这里就是从21条开始,取10条咯   
            return list;  
        }         
    } 
}

希望本文所述对大家的C#程序设计有所帮助。

相关文章

  • C#实现自定义圆角按钮的方法

    C#实现自定义圆角按钮的方法

    Winform中自带的button没有圆角属性,所以我们继承Button类,重写OnPaint事件来绘制圆角按钮。下面通过实例代码给大家介绍下C#实现自定义圆角按钮的方法,需要的朋友参考下吧
    2021-11-11
  • 使用C#实现生成一个绿色文件

    使用C#实现生成一个绿色文件

    这篇文章主要为大家详细介绍了如何使用C#实现生成一个绿色文件,可以免去安装的繁琐过程,直接运行,非常方便,有需要的小伙伴可以参考一下
    2024-04-04
  • C# 使用AE获取feature的属性及字段操作

    C# 使用AE获取feature的属性及字段操作

    这篇文章主要介绍了C# 使用AE获取feature的属性及字段操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • C#生成饼形图及添加文字说明实例代码

    C#生成饼形图及添加文字说明实例代码

    这篇文章主要介绍了C#生成饼形图及添加文字说明的方法,非常实用的功能,需要的朋友可以参考下
    2014-07-07
  • C#检查Windows是否安装了某个服务的方法

    C#检查Windows是否安装了某个服务的方法

    这篇文章主要介绍了C#检查Windows是否安装了某个服务的方法,涉及C#操作windows系统服务的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • 一文带你了解 C# DLR 的世界(DLR 探秘)

    一文带你了解 C# DLR 的世界(DLR 探秘)

    DLR 是 C#4.0 新引进来的概念,其主要目的就是为了动态绑定与交互。下面小编给大家带来一篇不错教程,一文带你了解 C# DLR 的世界,需要的朋友可以参考下
    2020-02-02
  • 解析C#设计模式编程中外观模式Facade Pattern的应用

    解析C#设计模式编程中外观模式Facade Pattern的应用

    这篇文章主要介绍了C#设计模式编程中外观模式Facade Pattern的应用,外观模式中分为门面(Facade)和子系统(subsystem)两个角色来进行实现,需要的朋友可以参考下
    2016-02-02
  • 浅谈c#中config.exe 引发的一些问题

    浅谈c#中config.exe 引发的一些问题

    下面小编就为大家分享一篇浅谈c#中config.exe 引发的一些问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-11-11
  • 关于C#中async/await的用法实例详解

    关于C#中async/await的用法实例详解

    这篇文章主要介绍了关于C#中async/await的用法,今天写一个demo彻底搞明白async/await的用法,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-02-02
  • C# 获取 PC 序列号的方法示例

    C# 获取 PC 序列号的方法示例

    这篇文章主要介绍了C# 获取 PC 序列号的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07

最新评论