想了解C#将DataTable转换成list的方法的相关内容吗,在本文为您仔细讲解C#将DataTable转换成list的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:C#,DataTable,转换,list,方法,下面大家一起来学习吧。
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;
}
}
}