• <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

            久久精品国产亚洲av麻豆蜜芽| 狠狠色丁香久久婷婷综合蜜芽五月| 亚洲国产精品18久久久久久| 色诱久久久久综合网ywww| 99久久精品费精品国产一区二区| 久久99国产精品一区二区| 国产亚洲精午夜久久久久久| 久久这里只有精品首页| 久久精品国产一区| 久久精品国产亚洲AV蜜臀色欲| 热99re久久国超精品首页| 亚洲va久久久久| 亚洲伊人久久大香线蕉苏妲己| 日本国产精品久久| 久久久久99精品成人片欧美| 一级做a爰片久久毛片毛片| 久久精品成人免费网站| 亚洲午夜久久久久久久久久| 精品国产综合区久久久久久| 亚洲国产精品无码久久久不卡| 久久久久久久国产免费看| 久久精品国产99久久久香蕉| 欧美丰满熟妇BBB久久久| 久久久WWW成人免费毛片| 久久久国产精品福利免费| 久久亚洲精品成人AV| 久久久久久久波多野结衣高潮| 久久久久久极精品久久久 | 久久伊人影视| 精品久久久无码中文字幕天天| 国产精品福利一区二区久久| 亚洲国产精品无码久久久蜜芽| 久久精品青青草原伊人| 国产一区二区久久久| 久久久久久久久久久| 亚洲国产精品18久久久久久| 久久国产AVJUST麻豆| 中文字幕无码久久久| 亚洲成av人片不卡无码久久| 亚洲精品久久久www| 亚洲精品成人网久久久久久|