首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >数据库调度操作

数据库调度操作
EN

Stack Overflow用户
提问于 2011-09-14 00:20:12
回答 5查看 166关注 0票数 1

我已经编写了一个餐厅管理应用程序。我有一个基于SQL Server2005的数据库,其中有一个名为OrdersItems的表。每隔5分钟,我希望读取该表中的所有行,并根据特定条件更新一些字段。

我不想在我的主应用程序中这样做,我更喜欢有一个替代引擎来执行这一任务。

哪种方法是执行此类任务的最佳方法?还要注意,这个表(OrdersItems)每次都在处理中,因为主应用程序必须始终运行并获得新的餐厅订单。

EN

回答 5

Stack Overflow用户

发布于 2011-09-14 00:22:31

你可以用create a SQL Server Agent job命令每五分钟更新一次。

如果您使用的是SQL Server Express edition,则不能使用SQL Server代理,因为它只包含在SQL Server的“较大”版本中。

在这种情况下,you can create your jobs manually使用批处理文件和Windows Task Scheduler。

票数 3
EN

Stack Overflow用户

发布于 2011-09-14 00:34:34

我绝对同意Christian和dougajmcdonald关于使用SQL Task/ Maintenance的观点。但是,由于您在标记中包含了c#,另一种方法是创建一个Windows Service。

这种方法的好处

  • 可以在未安装SQL Server代理(包括速成版)的计算机上运行
  • 可以在用户登录上下文之外运行。
  • 具有标准的stop start pause机制,这一点很容易理解。
  • 如果服务本身发生故障,可能会导致事件日志

This answer包含定期获取数据并执行的windows服务的模板。您可能只想更改DoStuff方法以执行存储过程

票数 2
EN

Stack Overflow用户

发布于 2011-09-14 00:39:35

创建一个dialog timer并让它activate一个存储过程。这具有完全包含在数据库中(没有外部进程)的优势,它不需要SQL代理(在Express上运行),并且在数据库分离/连接和备份/恢复操作中完全具有崩溃恢复能力(计划的作业将在新恢复的数据库上恢复后运行)。

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

https://stackoverflow.com/questions/7405163

复制
相关文章

相似问题

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