我的任务是生成大约 1'000'000 行并将其插入到 2 个表中。困难在于我必须插入现有的外键,所以我先从其他表中获取数据...然后我尝试生成具有 1000000 行的新 DataTable 以将其粘贴到 SqlBulk...但是这代需要太长时间(~每分钟 4000 行!)这是代码,也许有人可以帮助优化它......
public void GenerateData(DateTime fromDate, DateTime toDate, int Size)
{
DataTable theDatetime = new DataTable();
theDatetime.Columns.Add("Datetime", new DateTime().GetType());
theDatetime.Columns.Add("Date", new DateTime().GetType());
theDatetime.Columns.Add("Hour", new Int32().GetType());
DataTable theOverspeed = new DataTable();
theOverspeed.Columns.Add("CarNumber", new Int32().ToString().GetType());
theOverspeed.Columns.Add("Datetime", new DateTime().GetType());
theOverspeed.Columns.Add("DistrictCode", new Int32().GetType());
theOverspeed.Columns.Add("MarkCode", new Int32().GetType());
theOverspeed.Columns.Add("OwnerCode", new Int32().GetType());
theOverspeed.Columns.Add("RecognitorNumber", new Int32().GetType());
theOverspeed.Columns.Add("Region", new Int32().GetType());
theOverspeed.Columns.Add("RouteCode", new Int32().GetType());
theOverspeed.Columns.Add("Overspeed", new Int32().GetType());
theOverspeed.Columns.Add("Speed", new Int32().GetType());
Dictionary<DateTime, DateTime> Dates = new Dictionary<DateTime, DateTime>();
Random TheGenerator = new Random();
DataTable theCars = getCars();
DataTable theRecognitors = getRecognitors();
int[] sizes = new int[5];
for(int step = 0; step < 5; ++step)
{
DateTime Current1 = GetFifthDate(fromDate, toDate)[step];
DateTime Current2 = GetFifthDate(fromDate, toDate)[step+1];
int CurrentCount = GetFifthCount(Size)[step];
for (int i = 0; i < CurrentCount; ++i)
{
var aDate = GetRandomDate(Current1, Current2);
if (!Dates.ContainsKey(aDate))
{
InsertFact(theCars, aDate, theRecognitors,
theDatetime, theOverspeed);
Dates.Add(aDate, aDate);
}
else
{
i--;
}
}
}
和 InsertFact 方法
private void InsertFact(DataTable theCars,
DateTime theDate,
DataTable theRecognitor, DataTable theDatetime, DataTable theOverspeed)
{
Random theGenerator = new Random(DateTime.Now.Millisecond);
DataRow rowDate = theDatetime.NewRow();
rowDate["DateTime"] = theDate;
rowDate["Date"] = theDate.Date;
rowDate["Hour"] = theDate.Hour;
theDatetime.Rows.Add(rowDate);
int car = theGenerator.Next(theCars.Rows.Count);
int recognitor = theGenerator.Next(theRecognitor.Rows.Count);
DataRow rowOverspeed = theOverspeed.NewRow();
rowOverspeed["CarNumber"] = theCars.Rows[car][4];
rowOverspeed["Datetime"] = theDate;
rowOverspeed["DistrictCode"] = theRecognitor.Rows[recognitor][3];
rowOverspeed["MarkCode"] = theCars.Rows[car][3];
rowOverspeed["OwnerCode"] = theCars.Rows[car][2];
rowOverspeed["RecognitorNumber"] = theRecognitor.Rows[recognitor][2];
rowOverspeed["Region"] = theCars.Rows[car][1];
rowOverspeed["RouteCode"] = theRecognitor.Rows[recognitor][1];
rowOverspeed["Overspeed"] = theGenerator.Next(10, 40);
rowOverspeed["Speed"] = theGenerator.Next(100) > 40 ? 70 : 90;
theOverspeed.Rows.Add(rowOverspeed);}
获取识别器
private DataTable getRecognitors()
{
DataTable Result = new DataTable("Recognitors");
using (SqlConnection theConnection = new SqlConnection(str))
{
theConnection.Open();
SqlDataAdapter theAdapter = new SqlDataAdapter();
SqlCommand theCommand = new SqlCommand("Select * from Recognitor", theConnection);
theCommand.CommandType = System.Data.CommandType.Text;
theCommand.CommandTimeout = 0;
theAdapter.SelectCommand = theCommand;
theAdapter.Fill(Result);
}
return Result;
}
获取汽车
private DataTable getCars()
{
DataTable Result = new DataTable("Cars");
using (SqlConnection theConnection = new SqlConnection(str))
{
theConnection.Open();
SqlDataAdapter theAdapter = new SqlDataAdapter();
SqlCommand theCommand = new SqlCommand("Select * from Car", theConnection);
theCommand.CommandType = System.Data.CommandType.Text;
theCommand.CommandTimeout = 0;
theAdapter.SelectCommand = theCommand;
theAdapter.Fill(Result);
}
return Result;
}