问题 如何通过T-SQL在SQL Server 2008中创建预定作业?


我想创建一个在一段时间过后删除数据库记录的作业。例如,我在新闻表中有一个字段 Time Stamp 每个月,一个SQL查询就像我的数据库中的预定作业一样运行,并删除时间戳为两个月的新闻。一般来说,我想删除2个月前和更早的新闻,不要让我的桌子变成一张大桌子。我怎么能做到这一点?


7826
2018-03-13 17:10


起源



答案:


你应该 创造一份工作 在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

13
2018-03-13 17:51



N in的目的是什么? =N'...' - xyz
@xyz文本值前面的N表示以下文本的类型为nvarchar而不是varchar。有关这两种数据类型的区别,请参见此处: 链接 - Otto Abnormalverbraucher


答案:


你应该 创造一份工作 在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

13
2018-03-13 17:51



N in的目的是什么? =N'...' - xyz
@xyz文本值前面的N表示以下文本的类型为nvarchar而不是varchar。有关这两种数据类型的区别,请参见此处: 链接 - Otto Abnormalverbraucher


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


0
2018-03-13 17:14