栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C# > C#教程

C#过滤DataTable中空数据和重复数据的示例代码

C#教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C#过滤DataTable中空数据和重复数据的示例代码

C#过滤DataTable中的空数据和重复数据

string sql = "select name,age from user";
DataTable data = DB.ExecuteDataTable(string.Format(sql)); //得到DataTable

// ------------start 去重-------------------
string[] distinctcols = new string[(data.Columns.Count)];
foreach (DataColumn dc in data.Columns)
{
 distinctcols[dc.Ordinal] = dc.ColumnName;
}
DataView mydataview = new DataView(data);
DataTable data1 = mydataview.ToTable(true, distinctcols);
// ------------end  -------------------

// ------------start 去null-------------------
DataTable data2 = data1.Clone();//克隆表
foreach (DataRow drItem in data1.Rows)
{
	//过滤,判断条件的下标自己控制
 if (!string.IsNullOrWhiteSpace(drItem[0].ToString()) && !string.IsNullOrWhiteSpace(drItem[1].ToString()))
 {
  data2.Rows.Add(drItem.ItemArray);
 }
}
// ------------end-------------------


DataRow row = data2.NewRow();
data2.Rows.InsertAt(row, 0);
return data2;

附:c# datatable根据某个条件过滤数据

判断DataTable中某一行某列的数据为空值的办法

需要使用DataRow类自带的一个函数IsNull。

if(!DataRow.IsNull(index))

if(Convert.IsDBNull(Row.ItemArray[index]))

在DataReader(如SqlDataReader)有相同功能的IsDBNull函数

datatable根据某个条件过滤数据

public static DataTable TblFilter(DataTable sourceTable, string condition)
    {
      var tempDt = sourceTable.Clone();
      var rows = sourceTable.Select(condition);
      foreach (var dr in rows)
      {
 tempDt.importRow(dr);
      }
      return tempDt;
    }


    public static DataTable TblFilter(DataTable sourceTable, string condition, string[] columns)
    {
      var tempDt = new DataTable();
      foreach (var t in columns)
      {
 tempDt.Columns.Add(t, typeof(String));
      }
      var rows = sourceTable.Select(condition);
      foreach (var dr in rows)
      {
 var newDr = tempDt.NewRow();
 foreach (var t in columns)
 {
   newDr[t.Split(':')[0]] = dr[t.Split(':')[0]].ToString();
 }
 tempDt.Rows.Add(newDr);
      }
      return tempDt;
    }

sql语句中left,right函数取字段的左或者右几位数字

LEFt(shopid,4)

总结

到此这篇关于C#过滤DataTable中空数据和重复数据的文章就介绍到这了,更多相关C#过滤DataTable空数据和重复数据内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/121515.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号