11

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

4

2 回答 2

13

您应该在 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
于 2013-03-13T17:51:29.870 回答
0

您将需要创建一个SQL 代理作业来安排定期运行的作业。如果要使用 T-SQL 创建作业,请参阅如何:创建 SQL Server 代理作业 (Transact-SQL)

于 2013-03-13T17:14:30.730 回答