在日常开发过程中,有一个DataTable集合,里面有很多字段,现在要求针对某一列进行排序,如果该列为数字的话,进行ASC即可实现,但是该字段类型为string,此时排序就有点不正确了

protected void Page_Load(object sender, EventArgs e)
{
DataTable dt = new DataTable();
dt.Columns.Add("Name");
dt.Columns.Add("Age");//因为是字符串,所以排序不对
dt.Rows.Add("小明", "");
dt.Rows.Add("小张", "");
dt.Rows.Add("小红", "");
dt.Rows.Add("小伟", "");
dt.Rows.Add("小美", "");
dt.DefaultView.Sort = "Age ASC";
dt = dt.DefaultView.ToTable(); foreach (DataRow s in dt.Rows)
{
Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
}
Response.Write("------------------1----------------<br/>"); #region 方法1:将年龄补齐为2位,然后再进行排序,但是实际不应该有0(仅作参考)
for (int i = ; i < dt.Rows.Count; i++)
{
dt.Rows[i]["Age"] = dt.Rows[i]["Age"].ToString().PadLeft(, '');
}
dt.DefaultView.Sort = "Age ASC"; dt = dt.DefaultView.ToTable(); foreach (DataRow s in dt.Rows)
{
Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
}
#endregion Response.Write("------------------2----------------<br/>"); #region 方法2:创建新的DataTable,将Age类型变更为int类型
DataTable dtNew = dt.Clone();
dtNew.Columns["Age"].DataType = typeof(int);//指定Age为Int类型
foreach (DataRow s in dt.Rows)
{
dtNew.ImportRow(s);//导入旧数据
} dtNew.DefaultView.Sort = "Age ASC";
dtNew = dtNew.DefaultView.ToTable(); foreach (DataRow s in dtNew.Rows)
{
Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
}
#endregion Response.Write("-----------------3-----------------<br/>"); #region 方法3:添加一列,主要用于排序
dt.Columns.Add("AgeLength", typeof(int), "len(Age)");//添加该列时,DataTable列数据即生成 dt.DefaultView.Sort = "AgeLength,Age ASC";
dt = dt.DefaultView.ToTable(); foreach (DataRow s in dt.Rows)
{
Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
}
#endregion Response.Write("-----------------4-----------------<br/>"); #region 方法4:运用LinQ,将DataTable转换为集合,再调用集合自带的排序方法进行排序
foreach (DataRow s in dt.Rows.Cast<DataRow>().OrderBy(r => int.Parse(r["Age"].ToString())))
{
Response.Write(s["Age"].ToString() + "--" + s["Name"].ToString() + "<br/>");
}
#endregion
}

DataTable dataTable;
    1、排序
    1.1、利用查询排序

DataRow[] dataRows = dataTable.Select("条件", "id asc");
//或多列排序
DataRow[] dataRows = dataTable.Select("条件", "id asc,name asc,...");
//对所有的进行排序
DataRow[] dataRows = dataTable.Select("1=1", "id asc,name asc,...");

1.2、默认视图排序

DataView dataView = dataTable.DefaultView;
dataView.Sort = "id asc";
dataTable = dataView.ToTable();

2、搜索

如果单纯搜索,

DataRow[] dataRows = dataTable.Select("条件");
//或者
int id;
string name;
DataRow[] dataRows = dataTable.Select(string.Format(@"id={0} and name={1}",id,name));

如果对搜索结果排序,如同1.1。

说明:select方法如同sql语句对单表的查询,条件如同sql语句的where之后的部分,>,<,=,LIKE等都可以使用。
    3、合并
    合并的对象必须结构要一致,如果不一致先转换一致。然后,利用Merge方法,

DataTable dataTable1 = null;
DataTable dataTable2 = null;
dataTable1.Merge(dataTable2);

相关的DataTable的操作有,
行的初始化:http://blog.csdn.net/yysyangyangyangshan/article/details/7021107。
数组转DataTable:http://blog.csdn.net/yysyangyangyangshan/article/details/6947024。

LINQ的基础查询(使用LINQ to Object)

在此之前,我们先创建一个用于示例的数据源:

  • Student类:表示学生,包括学号、姓名及班级
  • Courses类:表示学生选择的课程,包括学号、课程名称及学时数
  • DataCreator类:静态类,通过GenerateData方法产生示例数据
  • 生成的数据如下:

    学号    姓名    班级    课程名称    学时 
    003        王五    二班    经济学    20 
    003        王五    二班    企业管理    20 
    003        王五    二班    财务管理    30 
    002        李四    一班    历史    20 
    002        李四    一班    政治    20 
    002        李四    一班    语文    30 
    001        张三    一班    数学    20 
    001        张三    一班    语文    20 
    001        张三    一班    物理    15

    Main方法中生成数据:

  • List<Student> students = new List<Student>();
    List<Courses> courses = new List<Courses>();
    DataCreator.GenerateData(students, courses);
  • 筛选

    LINQ中通过where子句筛选数据,where子句后跟条件,from后的对象都可作为where子句判断条件的主体。

  • 实际上from .. in ..语句类似于foreach语句,比如

  • from student in students 类似于 foreach(Student student in students)

  • student是students集合中的元素,那么通常在where语句中,可以使用student作为判断的依据,例如:

  • 筛选出一班的所有学生:

  • var query = from student in students
    where student.Class == "一班"
    select student;
    foreach (var s in query)
    {
    Console.WriteLine(s);
    }
  • 筛选学时大于等于20的课程:

  • var query = from course in courses
    where course.Credit >=
    select course;
  • 可使用&&或||来连接多个条件,如筛选出一班姓张的同学:

  • var query = from student in students
    where student.Class == "一班" && student.Name.StartsWith("张")
    select student;

    当然,并不是说条件语句中只能使用from后的对象,它可以使用任何对象作为判断依据(下面LINQ只作演示没实际意义):条件当前时间等于当前时间,此条件永远为真,故会查询出所有的学生资料。

  • var query = from student in students
    where DateTime.Now == DateTime.Now
    select student;
  • 下例以students集合的数量作为判断条件,当stuents的数量大于等于3时筛选出所有学生资料:
  • var query = from student in students
    where students.Count>=
    select student;
  • 下例筛选学号存在于ids集合中的学生:

  • String[] ids = {"","" };
    var query = from student in students
    where ids.Contains(student.ID)
    select student;
  • 查询选修了语文课程的学生资料:

  • var query = from student in students
    where (from cours in courses where cours.Name == "语文" select cours.StudentId).Contains(student.ID)
    select student;
    foreach (var s in query)
    {
    Console.WriteLine(s);
    }
  • 注意上例中使用了嵌套查询,students where语句中包含另一个LINQ语句,该语句从courses集合中返回选修了语文课程的学号,它是一个IEnumerable<String>集合,所以可以在此集合上使用IEnumerable的Contains方法,判断集合中是否包含当前student对象的ID,包含则返回true,即students的where语句为真,该student对象被添加入结果集合,反之不添加。

  • 排序

排序语句比较简单,基本语法为:

orderby .. ascending | descending[, ..ascending | descending]

其中ascending表示升序排列,descending表示降序排列

var query = from student in students
orderby student.ID ascending /*descending*/
select student;

可根据多个字段进行排序:

var query = from student in students
orderby student.ID ascending,student.Name descending
select student;

以下源码产生示例数据:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace LinqStudy
{
public static class DataCreator
{
public static void GenerateData(List<Student> students,List<Courses> courses)
{
students.Add(new Student("","张三", "一班"));
students.Add(new Student("", "李四", "一班"));
students.Add(new Student("", "王五", "二班"));
courses.Add(new Courses("", "数学", ));
courses.Add(new Courses("", "语文", ));
courses.Add(new Courses("", "物理", ));
courses.Add(new Courses("", "历史", ));
courses.Add(new Courses("", "政治", ));
courses.Add(new Courses("", "语文", ));
courses.Add(new Courses("", "经济学", ));
courses.Add(new Courses("", "企业管理", ));
courses.Add(new Courses("", "财务管理", ));
}
}
public class Student
{
public String Name { get; set; }
public String Class { get; set; }
public String ID { get; set; }
public Student(String id,String name, String c)
{
ID = id;
Name = name;
Class = c;
}
public override string ToString()
{
return String.Format("学号:{0}\t姓名:{1}\t班级:{2}", this.ID, this.Name, this.Class);
}
}
public class Courses
{
public String Name { get; set; }
public int Credit { get; set; }
public String StudentId { get; set; }
public Courses(String id,String name, int credit)
{
StudentId = id;
Name = name;
Credit = credit;
}
public override string ToString()
{
return String.Format("课程名称:{0}\t学时:{1}", this.Name, this.Credit);
}
}
}

整合:http://www.jb51.net/article/43343.htm

https://blog.csdn.net/yysyangyangyangshan/article/details/7349551

Linq(筛选与排序)

C#对DataTable里数据筛选排序的方法的更多相关文章

  1. 对DataTable里数据进行排序

    在日常开发过程中,有一个DataTable集合,里面有很多字段,现在要求针对某一列进行排序,如果该列为数字的话,进行ASC即可实现,但是该字段类型为string,此时排序就有点不正确了. 我也不多废话 ...

  2. 【转】DataTable 中数据筛选

    转自:http://blog.163.com/yangxw_2009/blog/static/155255217201032931755646/ 对DataTable进行过滤筛选的一些方法Select ...

  3. C#对DataTable里数据排序的方法

    protected void Page_Load(object sender, EventArgs e) { DataTable dt = new DataTable(); dt.Columns.Ad ...

  4. 去除DataTable重复数据的三种方法

    业务需求 最近做一个把源数据库的数据批次导出到目标数据库.源数据库是采集程序采集而来的原始数据库,所以需要对其进行一些处理(过滤一些为空,长度太短或太长,非法字符,重复数据)然后在进行入库. 其中要避 ...

  5. 去除DataTable重复数据的三种方法(转)

    转自:https://www.cnblogs.com/sunxi/p/4767577.html 业务需求 最近做一个把源数据库的数据批次导出到目标数据库.源数据库是采集程序采集而来的原始数据库,所以需 ...

  6. 对DataTable进行过滤筛选的一些方法Select,dataview

    当你从数据库里取出一些数据,然后要对数据进行整合,你很容易就会想到: DataTable dt = new DataTable();//假设dt是由"SELECT C1,C2,C3 FROM ...

  7. 批量插入数据, 将DataTable里的数据批量写入数据库的方法

    大量数据导入操作, 也就是直接将DataTable里的内容写入到数据库 通用方法: 拼接Insert语句, 好土鳖 1. MS Sql Server:   使用SqlBulkCopy 2. MySql ...

  8. [转]WPF and Silverlight 学习笔记(二十五):使用CollectionView实现对绑定数据的排序、筛选、分组

    在第二十三节,我们使用CollectionView实现了对于绑定数据的导航,除导航功能外,还可以通过CollectionView对数据进行类似于DataView的排序.筛选等功能. 一.数据的排序: ...

  9. #研发解决方案介绍#基于ES的搜索+筛选+排序解决方案

    郑昀 基于胡耀华和王超的设计文档 最后更新于2014/12/3 关键词:ElasticSearch.Lucene.solr.搜索.facet.高可用.可伸缩.mongodb.SearchHub.商品中 ...

随机推荐

  1. 在 Linux 平台中调试 C/C++ 内存泄漏方法(转)

    由于 C 和 C++ 程序中完全由程序员自主申请和释放内存,稍不注意,就会在系统中导入内存错误.同时,内存错误往往非常严重,一般会带来诸如系统崩溃,内存耗尽这样严重的后果.本文将从静态分析和动态检测两 ...

  2. android image加载中等待动画

    在布局中添加一个ImageViw和一个EditText. <ImageView android:id="@+id/loading_imageView_info" androi ...

  3. 【Algorithm】插入排序

    一. 算法描述 插入排序具体算法描述如下: 从第一个元素开始,该元素可以认为已经被排序 取出下一个元素,在已经排序的元素序列中从后向前扫描 如果该元素(已排序)大于新元素,将该元素移到下一位置 重复步 ...

  4. Oracle 12C -- 基于sequence的列的默认值

    12C支持先创建一个sequence,然后再将该sequence指定为某个列的值的默认表达式. 和"identity column"具有以下不同点: ·对列的个数没有限制 ·seq ...

  5. “The operation cannot be completed because the DbContext has been disposed” exception with lazy load disabled

    http://stackoverflow.com/questions/18261732/the-operation-cannot-be-completed-because-the-dbcontext- ...

  6. 【转】Swift 语言的设计错误

    Swift 语言的设计错误 在『编程的智慧』一文中,我分析和肯定了 Swift 语言的 optional type 设计,但这并不等于 Swift 语言的整体设计是完美没有问题的.其实 Swift 1 ...

  7. SharePoint 2013 Farm 安装指南——构建一个双层SharePoint Farm

    最近要对公司里的SharePoint进行升级,由于旧的系统SharePoint 2010已经有2年了,上面改动比较多,而且权限也很混乱了,所以下定决心要对其做一次升级,重新部署一台新的SharePoi ...

  8. FreeSWITCH收到重复的DTMF信号

    一.背景 用户是运营商手机,拨打的是运营商的固话号码进入的FreeSWITCH的IVR,进入IVR语音播报后,按指定的分机号呼相关人员. 二.现象 用户反映拨打124870找不到指定人员,以前是正常的 ...

  9. jmeter 压测duobbo接口,施压客户端自己把自己压死了

    jmeter 压测duobbo接口,jmeter代码不合理,导致每执行一次请求,会调用一次消耗内存的实例化.导致越压越慢,请求发不出去.这个时候需要考虑修改代码了. 截图中,tps越来越少. 原来初始 ...

  10. WPF 控件事件的一个小坑…

    最近想判断一下 Slider 是由鼠标点击而改变值,还是由程序内部代码改变的值,发现鼠标的各种事件比如 MouseDown.MouseUp.MouseLeftButtonDown 什么的,都没有任何反 ...