[Mono-bugs] [Bug 80075][Nor] New - bad performance problem with access of datarow column
bugzilla-daemon at bugzilla.ximian.com
bugzilla-daemon at bugzilla.ximian.com
Tue Nov 28 11:13:58 EST 2006
Please do not reply to this email- if you want to comment on the bug, go to the
URL shown below and enter your comments there.
Changed by informatique.internet at fiducial.fr.
http://bugzilla.ximian.com/show_bug.cgi?id=80075
--- shadow/80075 2006-11-28 11:13:58.000000000 -0500
+++ shadow/80075.tmp.13891 2006-11-28 11:13:58.000000000 -0500
@@ -0,0 +1,91 @@
+Bug#: 80075
+Product: Mono: Class Libraries
+Version: 1.2
+OS:
+OS Details:
+Status: NEW
+Resolution:
+Severity:
+Priority: Normal
+Component: Sys.Data
+AssignedTo: mono-bugs at ximian.com
+ReportedBy: informatique.internet at fiducial.fr
+QAContact: mono-bugs at ximian.com
+TargetMilestone: ---
+URL:
+Cc:
+Summary: bad performance problem with access of datarow column
+
+Description of Problem:
+When you access a datarow column, if the column name is not exactly (case
+sensitive) the same the performances are very poor.
+
+Steps to reproduce the problem:
+1. Try this test
+
+ public static void Main()
+ {
+
+
+ DataTable dt=new DataTable();
+ for (int i=0;i<100;i++)
+ {
+ dt.Columns.Add("nom_colonne"+i,typeof(string));
+ }
+ for (int j=0;j<100;j++)
+ {
+ DataRow r=dt.NewRow();
+ for (int k=0;k<10;k++)
+ {
+ r[k]=Guid.NewGuid().ToString();
+ }
+ dt.Rows.Add(r);
+ }
+ DateTime debut=DateTime.Now;
+ foreach (DataRow thisDataRow in dt.Rows)
+ {
+ string s="";
+ for (int i=0;i<dt.Columns.Count;i++)
+ {
+ string index="NOM_COLONNE"+i;
+ s+=thisDataRow[index].ToString();
+
+ }
+
+ }
+ DateTime fin=DateTime.Now;
+ TimeSpan dure=fin-debut;
+ Console.WriteLine("Durée :"+dure);
+
+
+ }
+
+
+Actual Results:
+Execution time : 12s
+
+If you replace :
+string index="NOM_COLONNE"+i;
+by
+string index="nom_colonne"+i;
+
+you get
+:0.166ms
+
+(one hundred times faster!)
+
+
+Expected Results:
+On MS.NET you get :
+
+0.125 (in the worse case) (MS.NET is 100x faster than mono in this case)
+and
+0.062 (in the best case) (MS.NET is only 2x faster than mono)
+
+
+
+
+How often does this happen?
+always
+
+Additional Information:
More information about the mono-bugs
mailing list