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

            久久露脸国产精品| 国产精品久久久久久久 | 亚洲精品无码久久毛片| 久久综合九色综合久99| 波多野结衣久久一区二区| 久久久久久国产精品免费无码| 国产精品久久毛片完整版| 人人狠狠综合久久亚洲高清| 性欧美丰满熟妇XXXX性久久久| 国产成人久久777777| 伊人久久综合无码成人网| 狠狠色丁香婷婷综合久久来来去 | 香蕉99久久国产综合精品宅男自| 狠狠色婷婷久久一区二区 | 亚洲一区精品伊人久久伊人| 996久久国产精品线观看| 久久久久久久91精品免费观看| 精品久久一区二区| 久久精品亚洲中文字幕无码麻豆| 久久综合亚洲色HEZYO国产 | 99国产欧美久久久精品蜜芽| 青青草原综合久久大伊人| 久久久久99精品成人片三人毛片| 99久久精品国产高清一区二区| 欧美日韩精品久久久久 | 99久久久精品免费观看国产 | 狠狠色丁香久久综合婷婷| 亚洲午夜无码久久久久| 久久亚洲精品国产亚洲老地址| 品成人欧美大片久久国产欧美| 久久91亚洲人成电影网站| 国产精品久久国产精品99盘 | 久久婷婷五月综合国产尤物app| 精品视频久久久久| 久久黄色视频| 久久精品国产亚洲AV不卡| 国产—久久香蕉国产线看观看 | 天天综合久久久网| 99久久国产综合精品成人影院| 日本精品久久久久中文字幕8| 丁香五月网久久综合|