高级会员
- 积分
- 854
- 金钱
- 716
- 贡献
- 61
- 注册时间
- 2024-9-13
|
楼主 |
发表于 2025-1-18 17:04:14
|
显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------
% m0 w+ t1 F, X7 K2 |USE msdb;0 t0 H' y" w/ a$ {; j- U
GO! P3 S* c9 U4 r" o; N$ ?
3 E/ s3 z+ f7 N5 P-- 如果作业已存在,则先删除它& Y$ k: M5 V1 `9 w/ Y% g3 l
IF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')
/ }: h7 w5 ~+ C5 Q EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';& T( v" E, Y& R+ _1 G
GO
. C! N4 j4 p/ V8 ~9 u% Z6 [
* T3 d! Z. u4 E8 [- O, U-- 创建新的作业9 j) v3 t: p h( P+ [; j7 a: v
EXEC sp_add_job
$ j* U9 J6 l" w# K) r& t @job_name = N'IncreaseUserCashJob', -- 作业名称
( h: u1 O( B6 N- W% z( T @enabled = 1, -- 启用作业 ~! C9 A; |& x/ C- q
@notify_level_eventlog = 0, -- 不在事件日志中记录作业状态更改
$ G' U; x. e) T) l7 y @notify_level_email = 0, -- 不发送电子邮件通知
: v# j$ d1 r" z( T$ V* O1 d @notify_level_netsend = 0, -- 不发送网络消息通知+ i, k9 O/ @, Y4 T" g! j
@notify_level_page = 0, -- 不发送寻呼通知. J- ?( m' ^$ p, v1 {3 Y
@delete_level = 0, -- 不自动删除作业
0 m2 Q8 e0 A, L7 t0 H; X3 h- t @description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述
9 v; x) y1 `/ W1 C* [! o1 n6 ? @category_name = N'[Uncategorized (Local)]', -- 作业类别5 ]+ R4 P+ z7 Y! m7 Y& f7 R6 c% B
@owner_login_name = N'YourLoginName', -- 作业所有者(请替换为实际的登录名): y3 `/ z' g. S1 Y/ t$ q2 C& W
@notify_email_operator_name = N''; -- 不指定电子邮件通知操作员
0 k7 g( h9 g3 k$ TGO
; J! P: K0 Z- c! U, D+ q- Y+ G# F. }0 |$ k
-- 为作业添加一个步骤
3 r# t7 e* f/ E& f, A$ f& l5 tEXEC sp_add_jobstep
- u$ H, o$ c9 w* h7 n. L @job_name = N'IncreaseUserCashJob', -- 作业名称4 |) N1 v7 @/ ^9 z' `3 M* t
@step_name = N'ExecuteStoredProcedure', -- 步骤名称
4 h$ ]7 ~% g/ _' j @subsystem = N'TSQL', -- 指定步骤使用的子系统(这里是Transact-SQL)
2 x& Y8 n, F4 R @database_name = N'account', -- 指定数据库名称* E2 R) m* B$ o
@command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)' P$ u) C/ q9 H; ~8 @! s
@retry_attempts = 5, -- 重试次数
' U0 v/ G |4 t# ]! o! r8 e @retry_interval = 5; -- 重试间隔(分钟)
z9 L7 g! ^5 }9 O1 v" VGO
9 k+ q, u$ J- j7 }% d3 Z2 C6 t- d; o# e0 k; O* x. d+ q" C
-- 为作业添加一个每分钟执行一次的调度. r: S& U } A' j/ i5 z
EXEC sp_add_schedule
8 p5 E* y1 b; g0 c+ Y @schedule_name = N'MinuteSchedule', -- 调度名称
) c/ O9 h2 l/ B l- A* d @freq_type = 4, -- 频率类型(4表示每日)( Q' T! @7 z2 @
@freq_interval = 1, -- 对于每日频率,这里设置为1表示每天都执行! z7 r! m# S. u( i
@freq_subday_type = 4, -- 子日频率类型(4表示分钟)
4 L+ ^7 C, h8 {$ A2 J% k @freq_subday_interval = 1, -- 子日频率间隔(每分钟执行一次)
/ {7 l# H/ [) j" j1 J# A @active_start_date = 20250118, -- 活动开始日期(格式YYYYMMDD)
K+ Q5 Z" S/ g @active_start_time = 0, -- 活动开始时间(以24小时制表示,0表示午夜)8 x6 k) c; ~" l
@active_end_date = 99991231, -- 活动结束日期(通常设置为一个遥远的未来日期)/ o: d, i+ [) g+ F4 X) h
@active_end_time = 235959; -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)7 P+ X, ~1 b2 j7 G% L# D9 U; V
GO* O9 N, W: Z& A$ l! P
! X5 J3 f" W7 E2 M) a: D. O: O5 X-- 将作业与调度关联起来- t: A4 g8 O" r5 x, `! ~
EXEC sp_attach_schedule 9 m: O. v! G8 U5 d
@job_name = N'IncreaseUserCashJob', -- 作业名称
. ?- e1 M# T; S/ ^" U& s o @schedule_name = N'MinuteSchedule'; -- 调度名称
" P# j; K6 U4 u3 }! KGO
* a$ ]1 M$ m- [% c* e7 c# `7 m3 ~! N9 m) K
-- 提交作业创建到SQL Server Agent: F/ p+ z1 x8 n% L @ A9 Q6 a
EXEC sp_add_jobserver
( {& @" K" ?# ?1 E. }, u- | @job_name = N'IncreaseUserCashJob', -- 作业名称. ?, _/ H1 a4 _0 m) U
@server_name = N'(LOCAL)'; -- 服务器名称(对于本地服务器使用'(LOCAL)')( [& J8 {5 h, k3 z: b; n9 f
GO1 ~% ^$ k/ P X( J/ F3 X c) n: @
8 }( Y5 N/ L! U* a' V/ Z }4 b' o' s0 O4 I6 c8 r
; }4 f; s0 [8 C; S6 i4 U$ H5 X' h- s1 d+ V! r* z( m) A0 w
( k" k, g5 |& U' a# f( `6 l4 v |
|