一定期間が経過した後にデータベースからレコードを削除するジョブを作成したいと考えています。たとえば、ニュース テーブルにフィールドがTime Stampあり、毎月 SQL クエリがデータベースに対してスケジュールされたジョブのように実行され、タイム スタンプが 2 か月前のニュースが削除されます。通常、テーブルが大きなテーブルにならないように、2 か月前以降のニュースを削除したいと考えています。どうすればこれを達成できますか?
			
			34052 次
		
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   に答える