高级会员
- 积分
- 867
- 金钱
- 728
- 贡献
- 62
- 注册时间
- 2024-9-13
|
楼主 |
发表于 2025-1-18 17:04:14
|
显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------
0 s: W5 \: H% c/ a' Q# u4 FUSE msdb;, s0 p' J, R7 \6 q9 [
GO
E- h2 ]- B' Z1 g% \5 Y! y7 w3 K: D' h# I: l3 B( e9 b
-- 如果作业已存在,则先删除它
( [- X* W y9 ~/ L# S) kIF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')
5 z# I& y( n( j- ` EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';
- \/ U' D; Y5 B: l/ u9 p6 O qGO
. m. h$ |. j7 y) x, O! m" h5 G" Y/ {5 Y P
-- 创建新的作业6 m1 ?) p. d6 s+ a6 Y0 b6 ^
EXEC sp_add_job
& z( ?% h" j9 S' O @job_name = N'IncreaseUserCashJob', -- 作业名称
# ^2 l# ]) _- k8 b0 `( [ @enabled = 1, -- 启用作业, X* k% `; {; B& B7 M
@notify_level_eventlog = 0, -- 不在事件日志中记录作业状态更改
7 O3 O7 w7 F# V; w L$ h% T @notify_level_email = 0, -- 不发送电子邮件通知
, K( |9 N$ w. C& Y! a @notify_level_netsend = 0, -- 不发送网络消息通知: V) M* ` V0 z$ b+ }
@notify_level_page = 0, -- 不发送寻呼通知
% l' }$ z# u5 W1 Y$ b% j3 { @delete_level = 0, -- 不自动删除作业; W% L3 V+ ?, }. W
@description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述3 ?; m! _- \/ Y" V! E4 ^0 c6 T0 G" }
@category_name = N'[Uncategorized (Local)]', -- 作业类别0 B1 q1 `/ g( u+ \, m
@owner_login_name = N'YourLoginName', -- 作业所有者(请替换为实际的登录名)
7 L# K0 c, I1 ]8 M- N* f @notify_email_operator_name = N''; -- 不指定电子邮件通知操作员3 [% S2 Z5 C8 b6 @
GO4 U3 Z2 ^9 ^4 a0 U$ H
4 Y4 K5 {# x, t-- 为作业添加一个步骤( T+ h5 W: |2 v s2 s
EXEC sp_add_jobstep
6 f9 J2 D8 W( R @job_name = N'IncreaseUserCashJob', -- 作业名称7 N- F$ d2 ~1 b, d: _# x! P& k
@step_name = N'ExecuteStoredProcedure', -- 步骤名称
+ s7 {8 u/ T8 S( F3 `* Z9 [ @subsystem = N'TSQL', -- 指定步骤使用的子系统(这里是Transact-SQL)
1 a: g. K, M( K- ?3 i- G0 Z @database_name = N'account', -- 指定数据库名称
7 a$ _5 g7 u! C: ?' r @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)
0 \) D9 k$ k ?) G; e) y, x0 H @retry_attempts = 5, -- 重试次数& D" A: }2 b2 @1 ]5 C" q
@retry_interval = 5; -- 重试间隔(分钟)* t1 |+ R! W3 ?% n! H% M( R
GO
: F g/ m( G/ S8 Y ]5 U
1 d$ R1 {( L O7 O2 B$ G-- 为作业添加一个每分钟执行一次的调度
9 y0 y0 A# m% s6 d1 e K+ W" fEXEC sp_add_schedule
4 }& q7 v# |7 E. o" h) ?0 @2 d6 t @schedule_name = N'MinuteSchedule', -- 调度名称* L' P1 p- C0 k* O# v, @( @
@freq_type = 4, -- 频率类型(4表示每日)
2 u. \, H/ d( [4 g0 D$ } @freq_interval = 1, -- 对于每日频率,这里设置为1表示每天都执行% E) A8 \1 M# Q
@freq_subday_type = 4, -- 子日频率类型(4表示分钟)
( d, e) }: B0 f* U$ D @freq_subday_interval = 1, -- 子日频率间隔(每分钟执行一次)6 {) D1 r. O" z7 ^. h8 A
@active_start_date = 20250118, -- 活动开始日期(格式YYYYMMDD)6 J2 `1 F/ u6 \
@active_start_time = 0, -- 活动开始时间(以24小时制表示,0表示午夜)# ?$ f+ O2 B" \: M' W
@active_end_date = 99991231, -- 活动结束日期(通常设置为一个遥远的未来日期)5 Y1 c( e- E4 N' ]& ]3 Y6 D/ F+ Z( Z
@active_end_time = 235959; -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)
; v6 m& T+ x9 ^% wGO
6 c: X& h& B' c* c+ K d) M$ B2 K) G5 x1 i
-- 将作业与调度关联起来
' O/ @5 f" [6 R3 ]! k+ pEXEC sp_attach_schedule : n3 c" I: p& i* N! w
@job_name = N'IncreaseUserCashJob', -- 作业名称) a* G2 B8 Y4 l0 n, U
@schedule_name = N'MinuteSchedule'; -- 调度名称
: m5 ?* A6 s* t: d1 V* KGO2 C) K! S9 @/ q: w; s
: M& g$ Z( F0 c L, g- e-- 提交作业创建到SQL Server Agent
: ]. t" g' X2 h, s2 X+ AEXEC sp_add_jobserver - R; M i1 ?& Y1 Z
@job_name = N'IncreaseUserCashJob', -- 作业名称% y8 S" r4 Q- k! n) H
@server_name = N'(LOCAL)'; -- 服务器名称(对于本地服务器使用'(LOCAL)')
5 Q% e% O6 `- }GO
; ` E: q( {0 c% H P% L: O; T% O9 z4 R2 O4 S
- V0 A& G( e2 ?- C
- J9 @0 K" y; }0 \- u! Q9 x4 A% A8 c' h7 \" {6 u. f
% _& q. l+ Y# Y; H \# J7 ?1 `& ?' @4 x |
|