zoukankan      html  css  js  c++  java
  • 对DataTable进行Distinct操作

    不说废话,直接看代码吧

            public static DataTable SelectDistinct(DataTable SourceTable, string keyFields)
            {
                if (SourceTable == null)
                    return null;
                DataTable dtRet = SourceTable.Clone();//定义返回记录表
                //获得参照列列表
                string[] sFields = keyFields.Split(',');//获得参照列列表
                if (sFields.Length == 0)
                    return SourceTable;
                DataRow[] dr = SourceTable.Select("", keyFields);//按参照列排序
                if (dr.Length == 0)
                    return SourceTable;
                DataRow lastRow = dtRet.NewRow();//定义对照值
                foreach (DataRow row in dr)//开始比对
                {
                    //定义列比对结果
                    int result = 0;
                    object oSrc;
                    object oDest;
                    //循环比对列值
                    for (int colIndex = 0; colIndex < sFields.Length; colIndex++)
                    {
                        //获得列值
                        oSrc = row[sFields[colIndex]];
                        oDest = lastRow[sFields[colIndex]];
                        //比较列值,不相等则退出循环
                        if (oSrc == DBNull.Value)
                        {
                            result = oDest == DBNull.Value ? 0 : -1;
                        }
                        else
                        {
                            result = oDest == DBNull.Value ? 1 : string.Compare(oSrc.ToString(), oDest.ToString(), false);
                        }
                        if (result != 0)
                            break;
                    }
                    //检查行比较结果
                    switch (result)
                    {
                        case 0://相同则放弃
                            break;
                        case -1://不同则加入,并将当前比较字符串赋给对照值
                        case 1:
                            dtRet.Rows.Add(row.ItemArray);
                            lastRow = row;
                            break;
                        default:
                            break;
                    }
                }
                return dtRet;
            }
    思路:对记录进行前后循环比对,保留不一致的。
  • 相关阅读:
    servlet上传图片 服务器路径(转)
    图片和提交servlet的相对和绝对路径
    Intel 的面试经历中国研究院
    CentOS-6.5-x86_64 最小化安装,已安装包的总数,这些包?
    西门子PLC学习笔记8-(计时器)
    这个周末我太累了
    windows7股票的,win8残疾人,安装Han澳大利亚sinoxn个时间,sinox它支持大多数windows软体
    net.sf.json 迄今 时刻 格式 办法
    ar命令提取.a时刻,一个错误 is a fat file (use libtool(1) or lipo(1) and ar(1) on it)
    POJ 2187: Beauty Contest(旋转卡)
  • 原文地址:https://www.cnblogs.com/cpmu/p/1721348.html
Copyright © 2011-2022 走看看