C# 关于 DataTable 的一些使用

1.抽取其中的distinct数据

DataTable dt;
 
DataView dv = dt.DefaultView;
 
 //ToTable()的第一个参数为是否DISTINCT
DataTable dtDistinct = dv.ToTable(true,"FieldName1","FieldName2","..."); 

2.使用Select筛选数据

 1 //查询
 2 DataRow[] drArr = dt.Select("C1='abc'");
 3 
 4 //模糊查询
 5 DataRow[] drArr = dt.Select("C1 LIKE 'abc%'");
 6 //另一种模糊查询的方法
 7 DataRow[] drArr = dt.Select("'abc' LIKE C1 + '%'", "C2 DESC");
 8 
 9 //排序
10 DataRow[] drArr = dt.Select("C1='abc'", "C2 DESC");

3.使用Find根据主键值查找数据 (为DataTable设置主键)

 
//为dt设置主键
 DataColumn[] col = new DataColumn[] { (dt.Columns["col1"]) };
 dt.PrimaryKey = col;
 //根据主键值查找
 DataRow dr = dt.Rows.Find("2");



//为dt设置主键(联合主键 col1 col2)
 DataColumn[] col = new DataColumn[] { (dt.Columns["col1"]), dt.Columns["col2"] };
 dt.PrimaryKey = col;

 object[] obj = new object[] { "0", "2" };
 //根据主键值查找 col1=0 && col2=2 的数据
 DataRow dr = dt.Rows.Find(obj);

如果我们要把这些按给定条件筛选出来的数据重新赋给一个新的DataTable

错误示范: 

 DataTable dtNew = dt.Clone();
 for (int i = 0; i < drArr.Length; i++)
 {
     dtNew.Rows.Add(drArr[i]);
 }

(这样会提示DataRow属于其他DataTable)

应该使用下面方法进行赋值:

 DataTable dtNew = dt.Clone();
 for (int i = 0; i < drArr.Length; i++)
 {
     dtNew.ImportRow(drArr[i]);
 }

参考链接:

https://blog.csdn.net/dengsunshine69/article/details/48004241

https://www.cnblogs.com/jianxm/archive/2009/03/31/1426681.html

https://blog.csdn.net/wfflzt/article/details/47010049

原文地址:https://www.cnblogs.com/catherinehu/p/10372878.html