• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            We do not always find visible happiness in proportion to visible virtue

            夢幻白樺林

            SHARE

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              14 Posts :: 58 Stories :: 62 Comments :: 0 Trackbacks

            公告

            常用鏈接

            留言簿(5)

            搜索

            •  

            最新隨筆

            最新評論

            閱讀排行榜

            /*

              已知 DataTable (first和 second) , 兩個DataTable中都有一列 ID,并且值唯一

              要求:組織一個新的DataTable ,滿足以下:
                   如果 first 存在于 second 中則更新first的Name列為second的Name
                   如果不存在則刪除該行
                   如果 second 的行不存在于first 就添加到 first中

            */
            using System;
            using System.Collections;
            using System.Text;
            using System.Data;

            namespace ConsoleApplication1
            {
                
            class Program
                {
                    
            static void Main(string[] args)
                    {
                        Demo d 
            = new Demo();
                        d.Run();          
                    }
                }

                
            class Demo
                {
                    DataTable first, second;       

                    
            public void Run()
                    {
                        
            int i, j;
                        first 
            = new DataTable();
                        first.Columns.Add(
            "ID");
                        first.Columns.Add(
            "Name");
                        DataRow dr;
                        
            for (i = 1; i < 100; i++)
                        {
                            dr 
            = first.NewRow();
                            dr[
            0= i;
                            dr[
            1= i;
                            first.Rows.Add(dr);
                        }
                        Console.Write(
            "\n\nold first:\n");
                        
            foreach (DataRow outRow in first.Rows)
                        {
                            Console.Write(outRow[
            0].ToString() + "  |  " + outRow[1].ToString() + "\n");
                        }

                        second 
            = first.Clone();
                        
            this.AddToSecond(100001);
                        
            this.AddToSecond(220000);
                        
            this.AddToSecond(555555);
                        
            this.AddToSecond(100,00100);
                        
            this.AddToSecond(15000150);
                        Console.Write(
            "\n\nold second:\n");
                        
            foreach (DataRow outRow in second.Rows)
                        {
                            Console.Write(outRow[
            0].ToString() + "  |  " + outRow[1].ToString() + "\n");
                        }
                        
            int len1 = first.Rows.Count;
                        
            int len2 = second.Rows.Count;
                        ArrayList DeleteRows 
            = new ArrayList();
                        ArrayList NewRows 
            = new ArrayList();
                        
            for (i = 0, j = 0; i < len1 && j < len2; )
                        {
                            
            string se = second.Rows[j][0].ToString();
                            
            string fi = first.Rows[i][0].ToString();
                            
            int compar = se.CompareTo(fi);
                            
            if (compar > 0//second > first
                            {
                                DeleteRows.Add(i
            ++);//已經刪除的
                            }
                            
            else if (compar == 0)
                            {
                                first.Rows[i][
            1= second.Rows[j][1].ToString() + "(修改)";
                                i
            ++;
                                j
            ++;
                            }
                            
            else
                            {
                                NewRows.Add(j
            ++); //新加的
                            }
                        }
                        
            if (i < len1)
                        {
                            
            //如果第一個沒有遍歷完,說明剩下的都是要刪除的
                            for (; i < len1; i++)
                            {
                                DeleteRows.Add(i);
                            }
                        }
                        
            else if (j < len2)
                        {
                            
            //如果第二個沒有遍歷完,說明剩下的都是要添加的
                            for (; j < len2; j++)
                            {
                                NewRows.Add(j);
                            }
                        }
                        
            //delete
                        int[] DeleteArray = (int[])DeleteRows.ToArray(typeof(int));
                        i 
            = DeleteArray.Length - 1;
                        
            while (i > -1)
                        {
                            
            //從后面開始刪
                            first.Rows.RemoveAt(DeleteArray[i]);
                            i
            --;
                        }

                        
            //add new
                        int[] NewArray = (int[])NewRows.ToArray(typeof(int));
                        
            for (i = 0; i < NewArray.Length; i++)
                        {
                            DataRow drNew 
            = first.NewRow();
                            drNew[
            0= second.Rows[NewArray[i]][0];
                            drNew[
            1= second.Rows[NewArray[i]][1].ToString() + "(新增)";
                            first.Rows.Add(drNew);
                        }
                        Console.Write(
            "\n\nresult second:\n");
                        
            foreach (DataRow outRow in first.Rows)
                        {
                            Console.Write(outRow[
            0].ToString() + "  |  " + outRow[1].ToString() + "\n");
                        }
                        Console.Read();
                    }

                    
            private void AddToSecond(object text1, object text2)
                    {
                        DataRow dr24 
            = second.NewRow();
                        dr24[
            0= text1;
                        dr24[
            1= text2;
                        second.Rows.Add(dr24);
                    }
                }
            }

            posted on 2007-06-12 23:53 colys 閱讀(294) 評論(0)  編輯 收藏 引用 所屬分類: C#.Net

            国产成人久久精品一区二区三区| AA级片免费看视频久久| 久久一区二区三区免费| 色狠狠久久综合网| 无码久久精品国产亚洲Av影片| 久久婷婷五月综合成人D啪 | 91精品国产综合久久婷婷| 国产国产成人精品久久| 69久久夜色精品国产69| 国产ww久久久久久久久久| 国产99久久九九精品无码| 国产A级毛片久久久精品毛片| 精品人妻久久久久久888| 亚洲色欲久久久综合网东京热| 天天躁日日躁狠狠久久| 久久久久免费视频| 久久精品国产亚洲AV麻豆网站| 久久久久99精品成人片| 久久线看观看精品香蕉国产| 久久人人爽人爽人人爽av| 精品久久久久久久久中文字幕| 囯产极品美女高潮无套久久久| 夜夜亚洲天天久久| 国产欧美一区二区久久| 久久天天躁狠狠躁夜夜avapp| 青青热久久国产久精品| 精品久久久久中文字| 2020久久精品国产免费| 午夜福利91久久福利| 精品乱码久久久久久夜夜嗨| 久久久久久久综合日本亚洲| 国产精品国色综合久久| 亚洲综合伊人久久大杳蕉| 无码国内精品久久综合88 | 久久免费大片| 久久99精品国产麻豆婷婷| 91精品观看91久久久久久 | 精品熟女少妇av免费久久| 色偷偷久久一区二区三区| 精品久久久一二三区| 久久综合久久综合亚洲|