如何从web服务方法调用存储过程,而不必等待存储过程完成,并让该方法完成所有其他活动?
举个例子(不是实际情况,但很容易理解):我有一个有1000万行的房子表,每年我都要根据土壤、建筑等计算每座房子的价值。
在年底之前,我提供了新的土壤和建筑参数,然后让数据库计算每栋房子的价值(通过从web服务方法调用的存储过程),但这可能需要几个小时。在同样的方法中,我希望能够告诉系统我已经开始计算(在它开始之后,而不是在开始之前)。
那么,我该如何避免超时,让我的web应用程序继续做其他事情呢?
谢谢。
发布于 2009-12-22 14:53:00
如果不依赖于存储过程的结果,则可以将存储过程调用包装在方法中,并使用
Thread statisticsThread = new Thread(new ThreadStart(YourSPWrapper));
statisticsThread.Priority = ThreadPriority.Lowest;
statisticsThread.Start();发布于 2009-12-22 15:01:36
您是在说调用一个不返回任何内容的SP吗?比如在服务器上启动一个任务?
您可以尝试使用异步委托来完成此任务,线程池可能是最简单的:
ThreadPool.QueueUserWorkItem(myDelegateFunction);
protected void myDelegateFunction(object state) {
//make your db call here and let the delegate fall out of scope
//if you need to set a variable saying it succeeded, set a global here
}然后,您可以随时启动委托,当有可用的线程资源时,它将在异步委托中执行。
发布于 2009-12-22 15:34:34
也许可以考虑使用SQL Server代理将查询排定为作业?如果作业需要按常规计划运行或极少运行,这一点尤其值得。
如果绝对必要,您还可以使用SQL脚本从您的job应用程序按需安排作业。只需确保代理服务正在运行,否则您的作业将无法启动。
https://stackoverflow.com/questions/1944563
复制相似问题