c# txt批量导入sqlite 代码实现

码奴一只 2012-09-24 02:05:52
cmd.CommandText = "insert into mqs_table_vendor(vendor_number,vendor_name)values(@corr_id,@corr_abbr)";
int count = 0;
while ((lines = streamreader.ReadLine()) != null)
{
count++;
if (count >= 2)
{
string[] strs = lines.Split(',');
string s_vendor_number = strs[0].ToString();
string vendor_name = strs[2].ToString();
cmd.Parameters.Clear();
cmd.Parameters.Add(new SQLiteParameter("@corr_id", s_vendor_number));
cmd.Parameters.Add(new SQLiteParameter("@corr_abbr", vendor_name));
cmd.ExecuteNonQuery();
}
}
MessageBox.Show("导出成功!", "信息");

以上是我的代码的一部分,导入一小部分可以,但是导入很多时就超时了,提示如下

检测到 ContextSwitchDeadlock
Message: CLR 无法从 COM 上下文 0x488ac8 转换为 COM 上下文 0x488c38,这种状态已持续 60 秒。拥有目标上下文/单元的线程很有可能执行的是非泵式等待或者在不发送 Windows 消息的情况下处理一个运行时间非常长的操作。这种情况通常会影响到性能,甚至可能导致应用程序不响应或者使用的内存随时间不断累积。要避免此问题,所有单线程单元(STA)线程都应使用泵式等待基元(如 CoWaitForMultipleHandles),并在运行时间很长的操作过程中定期发送消息。
...全文
167 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
码奴一只 2012-09-24
  • 打赏
  • 举报
回复
求大神帮助啊

110,572

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧