高级会员
- 积分
- 867
- 金钱
- 728
- 贡献
- 62
- 注册时间
- 2024-9-13
|
楼主 |
发表于 2025-1-18 17:04:14
|
显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------
) O9 T' y8 A( ^9 [3 `) S6 `+ r. }USE msdb;' d5 G) f2 J N6 }5 L+ R; [
GO% z/ `( N$ ~3 v
f' ]1 a* m" i-- 如果作业已存在,则先删除它. Z& p5 _. \% d1 W v& s% U/ g
IF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob'), Z7 C0 w1 M/ r' p0 U2 A
EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';
2 d; a% R, i# Y4 Y( E/ Z1 PGO
! n4 Y1 W1 x. Y" K
2 r3 b9 _. h( r) `7 \+ }-- 创建新的作业
% Y& e) d( _( ^0 J0 m$ D! `' J: cEXEC sp_add_job
2 M9 E7 o! C2 o/ e6 B" G @job_name = N'IncreaseUserCashJob', -- 作业名称
' O- I: X- I; @2 Q( r# n3 ^ @enabled = 1, -- 启用作业
" X' J3 O b9 u: Z; y- t3 ^- U @notify_level_eventlog = 0, -- 不在事件日志中记录作业状态更改
) q5 Z. c4 J0 h9 P @notify_level_email = 0, -- 不发送电子邮件通知9 ^0 X% P" t8 M: v
@notify_level_netsend = 0, -- 不发送网络消息通知& C5 \2 a$ K h3 z2 e
@notify_level_page = 0, -- 不发送寻呼通知
, W5 S1 Q" P1 D2 ]* Q; o0 T @delete_level = 0, -- 不自动删除作业5 Y* v/ ^! K" e3 u4 s5 k" t. o: K* u5 t
@description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述
5 |" D" l, s( G) Q3 t0 p/ ^! C f; j @category_name = N'[Uncategorized (Local)]', -- 作业类别
. F+ g; r8 e7 Q0 z7 ~* W @owner_login_name = N'YourLoginName', -- 作业所有者(请替换为实际的登录名)$ Q# I2 @; \5 Z
@notify_email_operator_name = N''; -- 不指定电子邮件通知操作员; t Q5 k f3 L, w
GO
3 o+ u/ i5 U9 ~% o) w" O" T/ @0 |/ V4 n5 {" p+ _
-- 为作业添加一个步骤
. {1 |" j# P* }. @' ]EXEC sp_add_jobstep
2 H2 x9 K- f- J! C @job_name = N'IncreaseUserCashJob', -- 作业名称( b! h- l, v' H! V0 }7 |1 J5 G1 _( F
@step_name = N'ExecuteStoredProcedure', -- 步骤名称7 L: T# p A! ]7 Y: ^4 C
@subsystem = N'TSQL', -- 指定步骤使用的子系统(这里是Transact-SQL)
" l' C8 f, {7 _& e E1 S @database_name = N'account', -- 指定数据库名称
* d$ a7 W6 D. M4 |7 g3 F; K7 C2 N @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)
$ v$ H. \/ U( X1 N. X7 K) ~4 L" T @retry_attempts = 5, -- 重试次数+ l0 l* [8 A8 y. M* W! I- Z! V- M
@retry_interval = 5; -- 重试间隔(分钟)* C- g* H9 V6 U8 N) o: @" }9 `7 e/ L& J
GO
& m: J9 ]7 {) m: D3 M* i
, h4 E1 A; J2 Q! g-- 为作业添加一个每分钟执行一次的调度
( N0 h: ?0 g6 E! x8 v+ j7 ]" ?EXEC sp_add_schedule
/ u2 @- o. z+ I6 y" c7 v" n9 Z8 D# s @schedule_name = N'MinuteSchedule', -- 调度名称! i' ?9 C$ ~" x. c
@freq_type = 4, -- 频率类型(4表示每日)1 [( ^5 q- J* K, G# y. Q# @
@freq_interval = 1, -- 对于每日频率,这里设置为1表示每天都执行. x1 @5 J" v4 ^9 }' I- p1 S
@freq_subday_type = 4, -- 子日频率类型(4表示分钟), P9 k" ~" P+ X& M$ {9 v+ i
@freq_subday_interval = 1, -- 子日频率间隔(每分钟执行一次)
% @' u6 U/ Y: L8 A* B @active_start_date = 20250118, -- 活动开始日期(格式YYYYMMDD)" R2 o$ A3 A7 E; Y4 J, L
@active_start_time = 0, -- 活动开始时间(以24小时制表示,0表示午夜)- h; o( `$ ^) F. P
@active_end_date = 99991231, -- 活动结束日期(通常设置为一个遥远的未来日期)
! D# S1 x9 Z$ N+ \2 J9 ^ @active_end_time = 235959; -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)
. \ ]. N0 k0 c; KGO5 S8 M5 U9 k# p% o8 V. Z2 l7 Q
7 c1 z9 o ^: y: |9 [-- 将作业与调度关联起来
( h7 d# E+ O C |EXEC sp_attach_schedule 7 U' G7 }! t* S3 i3 }
@job_name = N'IncreaseUserCashJob', -- 作业名称8 v" q+ y; K2 H7 `& p) u3 b0 |
@schedule_name = N'MinuteSchedule'; -- 调度名称- a: s$ K- G" O7 z$ A
GO) w! [9 l: P- O
% F! a6 O7 M* j4 H7 D+ e
-- 提交作业创建到SQL Server Agent( J5 B N) U6 }- x" N
EXEC sp_add_jobserver ; E! I0 N$ w% o8 x
@job_name = N'IncreaseUserCashJob', -- 作业名称
$ t, P: k+ h. g' n# D( Q9 T3 f @server_name = N'(LOCAL)'; -- 服务器名称(对于本地服务器使用'(LOCAL)')
( _" @4 T3 q( C$ v3 q8 @& i* fGO
8 J, `" |8 z2 T# G5 f/ G3 X2 c9 x- q c9 B k u* U3 x& r
% [9 t1 H% l }& `; j3 G C
& @9 [& @1 A# k& ]5 a$ ]$ X) N1 l# D1 P7 T. k7 L
+ ^7 c4 \1 n/ D, m |
|