• <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 閱讀(298) 評論(0)  編輯 收藏 引用 所屬分類: C#.Net

            国产精品99久久久久久宅男| 久久久一本精品99久久精品88| 久久成人永久免费播放| 99久久免费国产精品特黄| 亚洲精品国产美女久久久| 成人国内精品久久久久影院| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久久久久亚洲精品不卡| 少妇久久久久久被弄到高潮 | 亚洲国产成人久久综合一| 亚洲人AV永久一区二区三区久久| 久久精品卫校国产小美女| 国产精品成人精品久久久| 亚洲伊人久久精品影院| 狠狠人妻久久久久久综合蜜桃| 亚洲人成无码网站久久99热国产| 久久亚洲春色中文字幕久久久| 亚洲国产成人精品91久久久 | 偷偷做久久久久网站| 狠狠色丁香婷婷久久综合不卡| 久久99久国产麻精品66| 久久天天躁狠狠躁夜夜2020老熟妇| 人妻精品久久无码区| 久久久www免费人成精品| 久久综合给合综合久久| 久久精品国产福利国产琪琪| 国产精品久久一区二区三区| 国产精品禁18久久久夂久| 97久久国产综合精品女不卡| 亚洲精品无码久久毛片| 久久精品国产亚洲Aⅴ香蕉| 伊人久久综在合线亚洲2019| 欧美亚洲国产精品久久蜜芽| 久久99热只有频精品8| 久久青青草原精品国产| 精品蜜臀久久久久99网站| 亚洲成色WWW久久网站| 久久亚洲私人国产精品vA| 99精品国产99久久久久久97| 久久亚洲精品中文字幕| 国产精品久久久久…|