根據當月資料庫自動生成下個月資料庫 3

2021-04-16 13:11:39 字數 1174 閱讀 9429

--建立乙個每月最後乙個工作日執行的作業,呼叫上述儲存過程實現自動建立資料庫

use master

go--設定 sql agent 服務為自動啟動

exec msdb..sp_set_sqlagent_properties @auto_start=1

go--建立作業

exec msdb..sp_add_job @job_name=n'自動建庫處理'

--建立作業步驟

declare @sql varchar(800),@dbname varchar(250)

select @sql=n'exec sp_proccopydb'  --呼叫自動建庫的儲存過程

,@dbname=db_name()         --執行自動建庫處理的資料庫名

exec msdb..sp_add_jobstep @job_name=n'自動建庫處理',

@step_name = '建庫處理',

@subsystem = 'tsql',

@database_name=@dbname,

@command = @sql,

@retry_attempts = 5, --重試次數

@retry_interval = 5  --重試間隔

--新增作業排程(每月最後乙個工作日)

exec msdb.dbo.sp_add_jobschedule @job_name = n'自動建庫處理',

@name = n'時間安排',

@freq_type = 32,

@active_start_time = 0,  --0點開始執行

@freq_interval = 9,      --每月最後乙個工作日

@freq_subday_type = 1,

@freq_subday_interval = 0,

@freq_relative_interval = 16,

@freq_recurrence_factor = 1

-- 新增目標伺服器

exec msdb.dbo.sp_add_jobserver

@job_name = n'自動建庫處理' ,

@server_name = n'(local)'

/*--已知問題

由於sql生成指令碼的bug,有的資料庫可能無法用生成指令碼的方法進行處理

根據當月資料庫自動生成下個月資料庫 2

方法2.指令碼複製 use master goif exists select from dbo.sysobjects where id object id n dbo sp proccopydb and objectproperty id,n isprocedure 1 drop procedur...

根據當月資料庫自動生成下個月資料庫 2

方法2.指令碼複製 use master goif exists select from dbo.sysobjects where id object id n dbo sp proccopydb and objectproperty id,n isprocedure 1 drop procedur...

根據當月資料庫自動生成下個月資料庫 2

方法2.指令碼複製 use master goif exists select from dbo.sysobjects where id object id n dbo sp proccopydb and objectproperty id,n isprocedure 1 drop procedur...