Как создать запланированное задание в SQL server 2008 с помощью T-SQL?

Я хочу создать задание, которое удаляет записи из базы данных по истечении определенного периода времени. Например у меня есть поле в таблице новостей Time Stamp и каждый месяц SQL-запрос выполняется как запланированное задание в моей базе данных и удаляет новости, где отметка времени составляет два месяца. Как правило, я хочу удалить новости за 2 месяца назад и старше, чтобы не позволить моей таблице стать большой таблицей. Как я могу это сделать?

2 ответов


вы должны создать задание в SQL ниже приведен пример T-SQL для создания задания через SQL agent

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

вам нужно будет создать задание агента SQL запланировать периодическое выполнение задания. Если вы хотите создать задание с помощью T-SQL, обратитесь к как создать задание агента SQL Server (Transact-SQL).