高级会员
- 积分
- 812
- 金钱
- 678
- 贡献
- 57
- 注册时间
- 2024-9-13
|
楼主 |
发表于 2025-1-18 17:04:14
|
显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------1 z! C3 X1 L/ k3 N% i9 O. G& v! x
USE msdb;
# e* b- V' y( QGO8 t* R% U1 E3 L% Z U4 I" M5 i5 }) z8 W
) v2 [1 Y5 c+ T# h Q1 }9 g# ^0 D
-- 如果作业已存在,则先删除它& t% T0 ^8 w' w# X4 X6 e9 \) ?9 R# L
IF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')
3 p/ X( I/ g! }* C Q3 K6 F/ a EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';" {7 B* ^# z% E" n5 f. k' _& j
GO
2 e P& h- `( q6 N/ Z# z: ~; r7 x! l+ I8 c* {
-- 创建新的作业
6 `( x& i a1 y3 S" A! [EXEC sp_add_job
( P* q1 l! v& z2 v- | @job_name = N'IncreaseUserCashJob', -- 作业名称
- f7 L' C( _: Y" h1 o0 L3 e' o" E) }# v @enabled = 1, -- 启用作业
2 i# R5 F1 o6 g @notify_level_eventlog = 0, -- 不在事件日志中记录作业状态更改
; Z8 Y/ J1 j. l$ s8 A& x @notify_level_email = 0, -- 不发送电子邮件通知( D2 U. E9 k, g$ t0 P, K
@notify_level_netsend = 0, -- 不发送网络消息通知; D" F: k# c! `7 x5 u
@notify_level_page = 0, -- 不发送寻呼通知
* K: ?2 a; t, ?5 ]8 R# _, ?1 A/ X @delete_level = 0, -- 不自动删除作业; `. V) R/ A8 k) W* ~: b
@description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述' a7 a" x1 i$ M9 J# j+ ]
@category_name = N'[Uncategorized (Local)]', -- 作业类别
. W" @ K" D) O8 Q) n; ` @owner_login_name = N'YourLoginName', -- 作业所有者(请替换为实际的登录名)% }' C9 ~, n& n; g" U; l& s- ~
@notify_email_operator_name = N''; -- 不指定电子邮件通知操作员4 _& _: M* Y) U; k5 u, O
GO5 }0 P. T, b! F. `# R& h6 ^( N9 W
. i2 w+ X4 V8 ~3 k8 ]- C; A. V
-- 为作业添加一个步骤1 w0 R0 R5 s0 h8 N8 n, W; g
EXEC sp_add_jobstep & `( [9 J8 \7 j$ q% a
@job_name = N'IncreaseUserCashJob', -- 作业名称$ V) N: H& T6 g4 |2 C
@step_name = N'ExecuteStoredProcedure', -- 步骤名称/ V$ }3 q6 \! x2 P( ^6 _9 z
@subsystem = N'TSQL', -- 指定步骤使用的子系统(这里是Transact-SQL)% j& x4 ] C0 I' F m( |* S q- e
@database_name = N'account', -- 指定数据库名称
; i+ [1 r) J( d @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)2 p$ ?7 X0 C! Z7 Y; x8 D
@retry_attempts = 5, -- 重试次数
! M" E: @/ T2 s9 R: W @retry_interval = 5; -- 重试间隔(分钟)& I2 W1 ]+ d7 }$ {. Z# Z5 P9 y
GO
9 l" \3 b% y# U
3 v: u7 M) C* a/ j0 ?6 K-- 为作业添加一个每分钟执行一次的调度
( r0 L. L) l1 D, O( H3 ^& f4 c* hEXEC sp_add_schedule
) ^4 m: P6 u5 ~ @schedule_name = N'MinuteSchedule', -- 调度名称
7 ]6 q- Z! ~( P8 B @freq_type = 4, -- 频率类型(4表示每日)
* @9 F) U9 S2 j @freq_interval = 1, -- 对于每日频率,这里设置为1表示每天都执行4 @, d0 |( c8 { z& m4 @
@freq_subday_type = 4, -- 子日频率类型(4表示分钟)
' e6 q9 a. H- P8 s7 j6 [' U! T; y @freq_subday_interval = 1, -- 子日频率间隔(每分钟执行一次)$ k/ R% d% ^ Z' f) ?+ m2 E& O4 D
@active_start_date = 20250118, -- 活动开始日期(格式YYYYMMDD)1 }% o. _" A9 `- g, i( W. N- j
@active_start_time = 0, -- 活动开始时间(以24小时制表示,0表示午夜)8 ?' }4 r) m2 R" R2 G
@active_end_date = 99991231, -- 活动结束日期(通常设置为一个遥远的未来日期)% L* S- |6 z& u8 l/ l6 f8 s& N
@active_end_time = 235959; -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)
]4 s0 C: r1 n! u9 W3 c, p0 o+ NGO
# H% {. | }; u0 |. q& {$ x% g) t1 m v8 v- |
-- 将作业与调度关联起来
- L& J0 {3 K; dEXEC sp_attach_schedule * S1 w4 U& F+ B5 b7 A: w# p6 S% ?
@job_name = N'IncreaseUserCashJob', -- 作业名称
$ Q H5 O* J# ]+ U( t; E' f; g& m @schedule_name = N'MinuteSchedule'; -- 调度名称) t& H! F9 d, S" Z6 n
GO- {& z1 S! `3 y. O" j' J$ L
5 v. ?" G$ C1 N5 U-- 提交作业创建到SQL Server Agent9 C! R& d+ Z+ Q" x0 L- V
EXEC sp_add_jobserver # |- R) B2 `$ I( d
@job_name = N'IncreaseUserCashJob', -- 作业名称3 s/ c6 p6 q0 G( X, o
@server_name = N'(LOCAL)'; -- 服务器名称(对于本地服务器使用'(LOCAL)')& `; V8 X3 z% \7 I
GO
5 i" ]# _6 T" x$ ^4 S
8 G4 Q1 |+ X/ }7 U+ A
2 J" k, W0 }) ~
+ t" D* |& J- R6 y
$ U, k4 h$ @7 l" z
9 b( V$ ?, Z/ b4 l$ q5 o2 S8 s- } |
|