2012年12月26日 星期三

Visual C# 2010 InSert資料進入Table,發生錯誤訊息-20121225

在新增資料進入Table時,跳出錯誤訊息:[字串或二進位資料會被截斷]

其發生的原因:當Data長度大於欄位定義長度時,且在Insert 或 Update就會發生此錯誤訊息。

2012年12月4日 星期二

Visual C# 2010 陣列搜尋、拷貝、清除 - 20121203

陣列的搜尋:

  • Array.IndexOf( )方法:用來搜尋陣列中是否有符合的資料,若有找到就傳回該陣列元素的[註標值];若沒有找到的話,會傳回-1。     
          公式:Array.IndexOf( 陣列名稱 , 查詢資料  [ , 起始註標] [ , 查詢距離] );

※若找到傳回該陣列元素的註標值;相反的,若沒找到就回傳-1 。此陣列不必先經過排序,故每次搜尋資料都是由最前面開始,但資料量大時,查詢所花費時間會越多。

※使用Array.IndexOf( )方法來搜尋陣列中的資料,不必先經過排序,每次搜尋資料都是由最前面開始,當資料量大時,愈後面的資料查詢所花費的時間愈多,且資料的平均搜尋時間不平均。

範例:字串陣列 KK中有{"A","B","C","D","E","F"}六個陣列元素,若Str="E", Start=0 , Offset=2,
            其Array.IndexOf(KK , Str , Start , Offset)

結果:由標註1(=B)開始往下找3個陣列元素(=B、C、D),其內容是否有"E",傳回的值為-1。

  • Array.BinarySearch( )方法:使用之前陣列必須先經由小而大排序才可,此方法適用資料量大的陣列
          公式:Array.BinnarySearch( 陣列名稱 , 查詢資料 );

※此陣列必須先經過由小而大排序才可使用,適用於資料量大的陣列。

※使用Array.BinarySearch( )方法來二分化搜尋資料, 陣列必須先經過由小而大排序才可以使用,且此方法適用於資料量大的陣列中。


------------------------------------------------------------------------------------------------------

陣列的拷貝:

語法:Array.Copy( A , Aindex , B , Bindex , length );

  •          A:來源A陣列(被拷貝的陣列)。
  •  Aindex:來源A陣列的註標,由指定的註標開始複製。
  •          B:接收資料的目的B陣列。
  •  Bindex:目的B陣列的註標,由指定的註標開始儲存。
  •    length:複製的陣列元素個數。


陣列的清除:

語法:Array.Clear( A , Aindex , length );
  •          A:來源A陣列(被拷貝的陣列)。
  •  Aindex:來源A陣列的註標,由指定的註標開始清除。
  •    length:清除的陣列元素個數。

2012年12月1日 星期六

Visual C# 2010 陣列宣告、排序、反轉 - 20121130

陣列宣告方式:

方式一、資料型別 [ ] 陣列名稱;
                陣列名稱 = new 資料型別 [大小];

如:int [ ] myArray;
        myArray = new int[3];


方式二、資料型別 [ ] 陣列名稱 = new 資料型別[大小]{陣列初值}

如:int [ ] myArray = new int[3]{6,5,8}; 或 int [ ] myArray = new int[ ]{6,5,8};


※建立[陣列]時未設定初始值,如[數值資料型別]預設值為[零][字串資料型別]預設為[null][布林值資料型別]預設為[false]



陣列的排序:此指定一維物件由[小而大]作遞增排序

方法一、Array.Sort(陣列物件);

方法二、Array.Sort(陣列物件1,陣列物件2);


陣列的反轉:由[大而小]作遞減排列

方法、Array.Reverse(陣列物件);

※陣列必須先作(Sort)排列後,在作(Reverse)反轉。
※假若同時有兩個相關的陣列A和B,若以A陣列為基準由大到小做排序,其相關陣列需要同時反轉。寫法如下:

Array.Sort(A,B);                 //將A陣列先做由小而大排序,B陣列亦跟著修改。
Array.Reverse(A);             //將A陣列先做反轉,變成由大而小排序。
Array.Reverse(B);             //將B陣列做反轉。