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

            久久精品www| 国产99久久久久久免费看| 国产精品一区二区久久不卡| 久久亚洲AV成人无码| 国产亚洲美女精品久久久2020| 亚洲午夜久久久久妓女影院| 波多野结衣中文字幕久久| 狠狠色综合久久久久尤物| 久久精品无码av| 久久66热人妻偷产精品9| 精品国产乱码久久久久久1区2区| 亚洲中文字幕无码久久2020| a高清免费毛片久久| 久久综合日本熟妇| 国产精品一久久香蕉国产线看观看| 亚洲一区中文字幕久久| 狠狠综合久久综合88亚洲| 国产香蕉97碰碰久久人人| 久久亚洲中文字幕精品一区| 色综合久久中文综合网| 亚洲精品国产自在久久| 久久综合九色综合精品| 久久亚洲国产精品成人AV秋霞| 久久99精品久久久久久| 久久久亚洲欧洲日产国码二区| 久久丝袜精品中文字幕| 伊人久久大香线蕉影院95| 色综合久久久久综合体桃花网| 无码任你躁久久久久久老妇| 久久高潮一级毛片免费| 国产福利电影一区二区三区,免费久久久久久久精 | 亚洲AV无码成人网站久久精品大| 日本精品久久久久中文字幕| 精品伊人久久大线蕉色首页| 热久久国产欧美一区二区精品| 精品国产福利久久久| 久久av无码专区亚洲av桃花岛| 亚洲国产日韩综合久久精品| 久久精品无码一区二区app| 青青青青久久精品国产| 99久久精品费精品国产|