DataTable有一个Select方法,可以根据条件筛选出行,但如果逻辑算符是or,那么当条件的数目增大到一定程度时,CLR会抛出 StackOverException从而导致进程崩溃,用下面的代码测试了一下:
System.Data.DataTable dt = new DataTable();
for (int i = 0; i < 100; i++)
{
dt.Columns.Add("col" + i.ToString());
}
Console.WriteLine(">");
string cond = "1=1";
//args
int max;
max = int.Parse(Console.ReadLine());
for (int i = 0; i < max; i++)
{
DataRow dr = dt.NewRow();
dr["col0"] = i.ToString();
dt.Rows.Add(dr);
}
dt.AcceptChanges();
//
DateTime dtStart = DateTime.Now;
for(int i=0;i<max;i++)
{
cond += " or col0='" + i + "'";
}
dt.Select(cond);
DateTime dtEnd = DateTime.Now;
long l=dtEnd.ToFileTimeUtc()-dtStart.ToFileTimeUtc();
Console.WriteLine(l.ToString());
Console.ReadLine();
结果大约是条件达到350个左右时会抛出异常。
当然,我还是觉得筛选这样的问题应该在数据库中做:)
System.Data.DataTable dt = new DataTable();
for (int i = 0; i < 100; i++)
{
dt.Columns.Add("col" + i.ToString());
}
Console.WriteLine(">");
string cond = "1=1";
//args
int max;
max = int.Parse(Console.ReadLine());
for (int i = 0; i < max; i++)
{
DataRow dr = dt.NewRow();
dr["col0"] = i.ToString();
dt.Rows.Add(dr);
}
dt.AcceptChanges();
//
DateTime dtStart = DateTime.Now;
for(int i=0;i<max;i++)
{
cond += " or col0='" + i + "'";
}
dt.Select(cond);
DateTime dtEnd = DateTime.Now;
long l=dtEnd.ToFileTimeUtc()-dtStart.ToFileTimeUtc();
Console.WriteLine(l.ToString());
Console.ReadLine();
结果大约是条件达到350个左右时会抛出异常。
当然,我还是觉得筛选这样的问题应该在数据库中做:)
浙公网安备 33010602011771号