日期:2014-05-18  浏览次数:20933 次

问个小问题。各位帮忙解答一下。
这里有几万条数据,做一个winform窗体,在开始导入按钮里要做一个循环,插入到另一个网站里,
我试了一下,一点插入的时候程序直接就挂掉了。

所以想问一下各位。
我用TIMER控件。应该怎么控制。
我以前没用过TIMER控件。谢谢各位。
比如有一万条数据。我分100次,每次100条。SQL语句怎么写。

------解决方案--------------------
用多线程处理,首先要处理大量数据必须放到除主线程外的其他工作线程中来处理,这样才能响应界面的点击、刷新、更新进度条等等。也就是说主线程是用来创建窗体、更新窗体等用户界面操作的。


C# code
using System;
using System.Threading;
 
public class Worker
{
    // 在线程启动时此方法将被调用
    public void DoWork()
    {
        while (!_shouldStop) // 如果线程正在运行则打印信息
        {
            Console.WriteLine("worker thread: working...");
        }
        Console.WriteLine("worker thread: terminating gracefully.");
}
 
    public void RequestStop()
    {
        _shouldStop = true;
    }
    // Volatile这个关键字用来提醒编译器这个数据成员将被多线程访问
    private volatile bool _shouldStop; // 应该停止
}
 
public class Program
{
    static void Main()
    {
        // 创建一个线程对象. 这里并不是线程的开始
        Worker workerObject = new Worker();
       // 这里定义一个新的线程,注意这里没有使用ThreadStart委托
       // 另外构造函数接受的是对象的方法的名称
        Thread workerThread = new Thread(workerObject.DoWork);
        // 这里才是线程的真正开始
        workerThread.Start();
        Console.WriteLine("主线程: worker线程开始...");
 
        // 循环直到线程被激活,Thread的IsAlive这个属性表示线程是否为活动的
        while (!workerThread.IsAlive);
 
        // 将主线程暂停1毫秒,以允许worker这个线程完成自己的工作
        Thread.Sleep(1);
 
        // 需要worker这个线程自动停止
        workerObject.RequestStop();
 
// 使用Join这个方法来阻塞当前线程,直到对象的线程终止        workerThread.Join();
        Console.WriteLine("main thread: Worker thread has terminated.");
    }
}