我正在开发一个 Windows 应用程序,其中我正在上传一个文本文件。在该文本文件中有 5000 行,其中有逗号 [,] 分隔的数据。我在后端使用 oledb 连接[MS Access]。我正在从文件中获取逗号分隔的数据并将其插入数据库。
但正如我所观察到的,数据接近 15000-16000 条记录。插入时每秒需要将近 7 条记录。
我想提高这个速度。
这是否取决于我们在后端使用什么作为数据库?
sql server 2005可以代替MS Access提高速度吗?
请帮助我。
请参阅代码:
string file = openFileDialog1.FileName;
StreamReader inputData = new StreamReader(file);
while ((line = inputData.ReadLine()) != null)
{
subLine = line.Split(',');
/*Taking Unique ID from tradefile table*/
int ID=0;
try
{
da=new OleDbDataAdapter("select max(ID) from tradeFile",con);
DataSet ds=new DataSet();
da.Fill(ds);
for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
if (ds.Tables[0].Rows[i][0].ToString() == "")
{
}
else
{
ID = int.Parse(ds.Tables[0].Rows[i][0].ToString());
ID++;
}
}
}
catch(Exception ex)
{
MessageBox.Show(ex.Message);
}
try
{
string unknown="unknown Fileld";
con.Open();
// int j=subLine.Length;
//for(int i=0;i<subLine.Length;i++)
{
int i = 0;
//int j=subLine.Length;
//int index=subLine.Length-j;
cmd=new OleDbCommand(
"insert into tradeFile values('"+ID+"','"+
subLine[i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
subLine[++i].ToString()+"','"+subLine[++i].ToString()+"','"+
unknown+"')",con);
cmd.ExecuteNonQuery();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
con.Close();
}
//counter++;
}