当前位置: 首页 > news >正文

SQL Server 中定时调度调用存储过程

要在SQL中定时调度调用存储过程,你可以使用SQL Server代理(如果你正在使用SQL Server数据库)。下面是一些步骤来配置SQL Server代理以定时调度调用存储过程:

  1. 打开SQL Server Management Studio (SSMS) 并连接到你的SQL Server实例。

  2. 在对象资源管理器中,展开"SQL Server代理"节点。

  3. 右键单击"作业",然后选择"新建作业"。

  4. 在"新建作业"对话框中,输入作业的名称和描述。

  5. 在"步骤"节点中,单击"新建"创建一个新的作业步骤。

  6. 在"新建步骤"对话框中,输入步骤的名称和描述。

  7. 在"类型"下拉列表中,选择"Transact-SQL 脚本 (T-SQL)"。

  8. 在"脚本"文本框中,输入调用存储过程的T-SQL代码,例如:

 

sql复制代码

EXEC YourStoredProcedureName;
  1. 单击"确定"保存步骤。
  2. 在"新建作业"对话框中,选择"调度"节点。
  3. 单击"新建"创建一个新的调度计划。
  4. 在"新建调度"对话框中,定义调度的频率和时间,例如每天、每周、每月等。
  5. 单击"确定"保存调度计划。
  6. 在"新建作业"对话框中,选择"通知"节点(可选)。
  7. 单击"确定"保存作业。

完成上述步骤后,SQL Server代理将按照你定义的调度计划定时调用存储过程。你可以根据需要修改和扩展这些步骤,以满足你的特定要求。

请注意,这是针对SQL Server数据库的方法。如果你使用的是其他数据库管理系统(如MySQL、Oracle等),它们可能有自己的定时调度机制。你可以参考相应数据库的文档,以了解如何定时调度调用存储过程。

要批量创建存储过程和调度作业,你可以编写一个脚本,其中包含创建存储过程和调度作业的T-SQL代码,并在SQL Server Management Studio (SSMS)中执行该脚本。以下是一个简单的示例,演示如何批量创建存储过程和调度作业:

  1. 在文本编辑器中创建一个新的SQL脚本文件,例如"CreateProceduresAndJobs.sql"。

  2. 在脚本文件中,编写创建存储过程的T-SQL代码。例如:

 

sql复制代码

CREATE PROCEDURE Procedure1
AS
BEGIN
-- 存储过程逻辑
END
GO
CREATE PROCEDURE Procedure2
AS
BEGIN
-- 存储过程逻辑
END
GO

你可以根据需要添加更多的存储过程代码。

  1. 接下来,编写创建调度作业的T-SQL代码。例如:

 

sql复制代码

USE msdb;
GO
-- 创建作业1
EXEC dbo.sp_add_job
@job_name = N'Job1',
@enabled = 1,
@description = N'调度作业1';
GO
-- 添加作业步骤
EXEC dbo.sp_add_jobstep
@job_name = N'Job1',
@step_name = N'Step1',
@subsystem = N'TSQL',
@command = N'EXEC Procedure1;', -- 调用存储过程1
@on_success_action = 1; -- 成功时结束作业
GO
-- 创建调度计划
EXEC dbo.sp_add_schedule
@schedule_name = N'Schedule1',
@enabled = 1,
@freq_type = 4, -- 每天
@freq_interval = 1, -- 每1天
@active_start_time = 000000; -- 开始时间
GO
-- 将调度计划绑定到作业
EXEC dbo.sp_attach_schedule
@job_name = N'Job1',
@schedule_name = N'Schedule1';
GO

你可以根据需要添加更多的作业和调度计划代码。

  1. 保存脚本文件。
  2. 打开SQL Server Management Studio (SSMS) 并连接到你的SQL Server实例。
  3. 在SSMS中,打开一个新的查询窗口。
  4. 将脚本文件的内容复制到查询窗口中。
  5. 执行查询窗口中的脚本,可以通过点击工具栏上的"执行"按钮或按F5键来执行。

执行完毕后,SSMS将按照脚本中的定义创建存储过程和调度作业。你可以根据需要修改脚本中的存储过程和调度作业的名称、逻辑、调度计划等。使用脚本的方式可以方便地批量创建和管理存储过程和调度作业。

http://www.lryc.cn/news/213556.html

相关文章:

  • SpringCloud(三) Ribbon负载均衡
  • vue2:路由前置守卫无法获取到this.$store.state.xxx
  • Unity的碰撞检测(五)
  • Flutter笔记:Flutter的应用生命周期状态(lifecycleState)管理
  • 代碼隨想錄算法訓練營|第五十四天|300.最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组。刷题心得(c++)
  • 正点原子嵌入式linux驱动开发——Linux 串口RS232/485/GPS 驱动
  • HDFS工作流程和机制
  • CMMI/ASPICE认证咨询及工具服务
  • 【NI-DAQmx入门】计数器
  • Python爬取读书网的图片链接和书名并保存在数据库中
  • js解决加油站
  • 【c++|opencv】二、灰度变换和空间滤波---5.中值滤波
  • python之pytorch多进程
  • sqoop 抽数报错com.mysql.cj.exceptions.WrongArgumentException: HOUR_OF_DAY: 2 -> 3
  • 【Acwing170】加成序列(dfs+迭代加深+剪枝)题解和一点感想
  • Android开发知识学习——Kotlin进阶
  • iOS使用AVCaptureSession实现音视频采集
  • springboot和flask整合nacos,使用openfeign实现服务调用,使用gateway实现网关的搭建(附带jwt续约的实现)
  • 深入浅出排序算法之基数排序
  • CSS选择器、CSS属性相关
  • 设计模式(21)中介者模式
  • JVM虚拟机:通过一个例子解释JVM中栈结构的使用
  • 会自动写代码的AI大模型来了!阿里云推出智能编码助手通义灵码
  • 如何公网远程访问本地WebSocket服务端
  • python 练习 在列表元素中合适的位置插入 输入值
  • 企业级JAVA、数据库等编程规范之命名风格 —— 超详细准确无误
  • 有什么可以自动保存微信收到的图片和视频的方法么
  • 面试算法46:二叉树的右侧视图
  • vite配置terser,压缩代码及丢弃console
  • R语言使用surveyCV包对NHANES数据(复杂调查加权数据)进行10折交叉验证