本文实例讲述了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 = ;  

     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 > )  

         {  

             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 = ; //每页显示十条数据  

  

             //获取总页数  

             pageCount = list.Count % pageSize ==  ? ((list.Count - pageSize >=  ? (list.Count / pageSize) : (list.Count ==  ?  : ))) : list.Count / pageSize + ;  

  

             //这个list 就是取到10条数据  

             //Skip跳过序列中指定数量的元素,然后返回剩余的元素。  

             //Take序列的开头返回指定数量的连续元素。  

             list = list.Skip(pageSize * (pageIndex - )).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 > )  

            {  

                //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=;//每页显示多少条数据。              

            int pageCount; //总页数。  

            int currentPage=;//当前页。--这里假设当前页为第3页。  

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

C#将DataTable转换成list的方法的更多相关文章

  1. DataTable 转换成 Json的3种方法

    在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>.DataTable转换为Json格式.特别在使用Extjs框架的时候,A ...

  2. C#中对象,字符串,dataTable、DataReader、DataSet,对象集合转换成Json字符串方法。

    C#中对象,字符串,dataTable.DataReader.DataSet,对象集合转换成Json字符串方法. public class ConvertJson { #region 私有方法 /// ...

  3. DataTable转换成IList<T>的简单实现

    DataTable的无奈 很多时候,我们需要去操作DataTable.但DataTable的操作,实在是太不方便了.Linq?lambda表达式?统统没有... 特别是对现有结果集做进一步筛选,这样的 ...

  4. 将DataTable转换成CSV文件

    DataTable用于在.net项目中,用于缓存数据,DataTable表示内存中数据的一个表.CSV文件最早用在简单的数据库里,由于其格式简单,并具备很强的开放性,所以起初被扫图家用作自己图集的标记 ...

  5. DataTable转换成json字符串

    将DataTable里面的行转换成json字符串方法: #region DataTable转为json /// <summary> /// DataTable转为json /// < ...

  6. 将DataSet(DataTable)转换成JSON格式(生成JS文件存储)

    public static string CreateJsonParameters(DataTable dt) { /**/ /**/ /**/ /* /*********************** ...

  7. 将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据

    领导让在存储过程中批量添加数据,找出效率最高的,我看到后台代码后,发现可以将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据,知道还有其 ...

  8. DataTable转换成匿名类的List类型

    DataTable转换成匿名类的List类型   因为匿名类是不能够 Activator.CreateInstance进行反射实例化的 /// <summary> /// 匿名类的转换方式 ...

  9. 将DataTable转换成Json格式

    方法一: 将DataTable数据拼接成json字符串,方法如下: ///<summary> /// dataTable转换成Json格式 ///</summary> ///& ...

随机推荐

  1. CSS 定义上划线、下划线、删除线代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. editplus批量删除重复行(编辑-删除-删除重复行)

    editplus快速删除重复数据 多行文本,有些行的文字或数据是重复的,该怎么删除重复部分,只留下不重复的部分?很多人对这个问题感到无比头疼,Editplus同样能快速帮你删除数据. 那么,editp ...

  3. iOS团队开发者测试

    那么你需要在你下载证书的那个电脑上从钥匙串-->选择证书-->右键到处证书,保存为.p12的证书,以后这个证书拷贝到任何电脑上去都是可以使用的! 本来只有一台电脑可以测试, 现在要团队开发 ...

  4. UITapGestureRecognizer

    UITapGestureRecognizer IOS的手势非常多, 但是特别容易其他视图起冲突的手势,要数UITapGestureRecognizer 于是有了gestureRecognizerSho ...

  5. 如何用rake tasks 生成migration对应的sql

    how-to-use-rake-tasks-to-generate-migration-sql Rakefile文件里有load_tasks的方法 http://api.rubyonrails.org ...

  6. Tushare的安装

    TuShare是一个免费.开源的python财经数据接口包.主要实现对股票等金融数据从数据采集.清洗加工到数据存储的过程,能够为金融分析人员提供快速.整洁.和多样的便于分析的数据. 考虑到python ...

  7. poj1258 Agri-Net 最小生成树

    Agri-Net Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 44032   Accepted: 18001 Descri ...

  8. 利用 FFmpeg palettegen paletteuse 生成接近全色的 gif 动画

    下载FFmpeg-VideoToGif-v1.0.bat.7z FFmpeg 2.6 及以上版本有效 未使用palette时 使用palette后 @echo off set inFile=2015. ...

  9. codeforces A. Puzzles 解题报告

    题目链接:http://codeforces.com/problemset/problem/337/A 题意:有n个学生,m块puzzles,选出n块puzzles,但是需要满足这n块puzzles里 ...

  10. iphone越狱还原

    在Cydia 里安装Impactor 就行了 .在操作时需要全程联网: .请至少保证 % 的电量以防止在恢复过程出现断电的情况(建议将设备连接至电源): .设备将恢复至出厂状态,所有用户数据都将被清除 ...