小编典典

如何通过T-SQL在SQL Server 2008中创建计划作业?

sql

我想创建一个在一段时间后从数据库中删除记录的作业。例如,我在新闻表中有一个字段,Time Stamp每个月都有一个SQL查询像计划的作业一样在我的数据库上运行,并删除时间戳为两个月大的新闻。通常,我想删除2个月或更早的新闻,以免我的桌子变成大桌子。我怎样才能做到这一点?


阅读 209

收藏
2021-04-17

共1个答案

小编典典

您应该在SQL中创建作业,下面是通过SQL代理创建作业的示例T-SQL

USE msdb ;
GO
EXEC dbo.sp_add_job
    @job_name = N'Weekly Sales Data Backup' ;
GO
EXEC sp_add_jobstep
    @job_name = N'Weekly Sales Data Backup',
    @step_name = N'Set database to read only',
    @subsystem = N'TSQL',
    @command = N'ALTER DATABASE SALES SET READ_ONLY', 
    @retry_attempts = 5,
    @retry_interval = 5 ;
GO
EXEC dbo.sp_add_schedule
    @schedule_name = N'RunOnce',
    @freq_type = 1,
    @active_start_time = 233000 ;
USE msdb ;
GO
EXEC sp_attach_schedule
   @job_name = N'Weekly Sales Data Backup',
   @schedule_name = N'RunOnce';
GO
EXEC dbo.sp_add_jobserver
    @job_name = N'Weekly Sales Data Backup';
GO
2021-04-17