如何修改以下代码以一次运行插入语句100,但如果总共没有100次运行,也会运行。它也需要能够运行最后几个超过100%的运行。今天有一个非常缓慢的大脑日。每100次迭代运行一次函数,但也捕获最后一次
if (oleDataBaseConnection.HasRows())
{
int counter = 0;
Spinner spinner = new Spinner();
StringBuilder postgresQuery = new StringBuilder();
Dictionary<string, string> postgreSQLQueries = TypeConversion.GetQueryDictionary("POSTGRESQL");
while (oleDataBaseConnection.NextRecord())
{
string postgreSQLInsertQuery;
postgreSQLQueries.TryGetValue("INSERT", out postgreSQLInsertQuery);
postgreSQLInsertQuery = postgreSQLInsertQuery.Replace("{0}", tableName);
spinner.Turn();
postgresQuery.Append(postgreSQLInsertQuery);
postgresQuery.Append("(");
int columnCounter = 0;
//add a column parameter to query for each of our columns
foreach (KeyValuePair<string, string> t in destinationColumnData)
{
postgresQuery.Append(t.Key + ",");
columnCounter++;
}
postgresQuery = postgresQuery.Remove(postgresQuery.Length - 1, 1);
postgresQuery.Append(") ");
postgresQuery.Append("VALUES (");
//Loop through values for column names/types
for (int i = 0; i < columnCounter; i++)
{
if (String.IsNullOrEmpty(oleDataBaseConnection.GetFieldById(i)))
{
postgresQuery.Append("NULL, ");
}
else
{
switch (foobar[i].ToUpper())
{
case "TEXT":
postgresQuery.Append("$$" + oleDataBaseConnection.GetFieldById(i) + "$$, ");
break;
case "GEOMETRY":
postgresQuery.Append("ST_GeomFromText('" + oleDataBaseConnection.GetFieldById(i) + "'), ");
break;
default:
postgresQuery.Append(oleDataBaseConnection.GetFieldById(i) + ", ");
break;
}
}
}
postgresQuery = postgresQuery.Remove(postgresQuery.Length - 2, 2);
postgresQuery.Append(") ");
counter++;
//run 100 insert statements at a time
if (counter % 100 == 0)
{
postgresSQLDBConnection.PostgreSQLExecutePureSqlNonQuery(postgresQuery.ToString());
postgresQuery.Clear();
}
}
}
如果你知道的记录数事先你可以简单地递减和测试。第一批将包含更少的记录,其余的将有数百个。 – 2012-03-29 07:57:48