首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在不等待存储过程完成的情况下调用它?

如何在不等待存储过程完成的情况下调用它?
EN

Stack Overflow用户
提问于 2009-12-22 14:45:38
回答 5查看 3.5K关注 0票数 2

如何从web服务方法调用存储过程,而不必等待存储过程完成,并让该方法完成所有其他活动?

举个例子(不是实际情况,但很容易理解):我有一个有1000万行的房子表,每年我都要根据土壤、建筑等计算每座房子的价值。

在年底之前,我提供了新的土壤和建筑参数,然后让数据库计算每栋房子的价值(通过从web服务方法调用的存储过程),但这可能需要几个小时。在同样的方法中,我希望能够告诉系统我已经开始计算(在它开始之后,而不是在开始之前)。

那么,我该如何避免超时,让我的web应用程序继续做其他事情呢?

谢谢。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2009-12-22 14:53:00

如果不依赖于存储过程的结果,则可以将存储过程调用包装在方法中,并使用

代码语言:javascript
复制
        Thread statisticsThread = new Thread(new ThreadStart(YourSPWrapper));
        statisticsThread.Priority = ThreadPriority.Lowest;
        statisticsThread.Start();
票数 8
EN

Stack Overflow用户

发布于 2009-12-22 15:01:36

您是在说调用一个不返回任何内容的SP吗?比如在服务器上启动一个任务?

您可以尝试使用异步委托来完成此任务,线程池可能是最简单的:

代码语言:javascript
复制
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
}

然后,您可以随时启动委托,当有可用的线程资源时,它将在异步委托中执行。

票数 2
EN

Stack Overflow用户

发布于 2009-12-22 15:34:34

也许可以考虑使用SQL Server代理将查询排定为作业?如果作业需要按常规计划运行或极少运行,这一点尤其值得。

如果绝对必要,您还可以使用SQL脚本从您的job应用程序按需安排作业。只需确保代理服务正在运行,否则您的作业将无法启动。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1944563

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档