Я хочу создать задание, которое удаляет записи из базы данных по прошествии некоторого времени. Например, у меня есть поле в таблице новостей Time Stamp
, и каждый месяц SQL-запрос выполняется как запланированное задание против моей базы данных и удаляет новости, когда метка времени составляет два месяца. Обычно я хочу удалить новости за 2 месяца назад и старше, чтобы не позволить моей таблице стать большой таблицей. Как я могу это сделать?
Как создать запланированное задание на SQL Server 2008 через T-SQL?
Ответ 1
вы должны создать задание в SQL ниже приведен пример T-SQL для создания задания через 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
Ответ 2
Вам нужно будет создать SQL Agent Job, чтобы запланировать периодическое выполнение задания. Если вы хотите создать задание с помощью T-SQL, обратитесь к Как создать работу агента SQL Server (Transact-SQL).