高级会员
- 积分
- 883
- 金钱
- 742
- 贡献
- 64
- 注册时间
- 2024-9-13
|
发表于 2025-1-18 17:04:14
|
显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------& t+ l5 y3 `+ ^: ]( T5 m0 U
USE msdb;3 e+ V' ~9 q; Q5 p$ ^6 n
GO! D5 ^- Q# i+ N. Y3 V
3 G8 W! k- i% g9 R* I
-- 如果作业已存在,则先删除它
, o3 p$ f0 h4 F6 x, ]/ VIF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')
6 c- R+ X \2 r# i% R EXEC sp_delete_job @job_name = N'IncreaseUserCashJob'; d) ^% m h( Y3 o, w7 ]5 F+ M1 h
GO/ @4 Y/ }! S: R/ a, Z2 ]3 f ]) f
+ J6 K) c- G2 w8 O' G-- 创建新的作业 X, L, O2 k5 E! m3 G0 m, q9 |
EXEC sp_add_job
1 b4 D$ F3 j8 e( p0 N @job_name = N'IncreaseUserCashJob', -- 作业名称
; f( [/ O5 j$ [8 M- `- ] _+ k- q @enabled = 1, -- 启用作业' N5 ] ` ~% [
@notify_level_eventlog = 0, -- 不在事件日志中记录作业状态更改. |) R$ a! M% ]% c A
@notify_level_email = 0, -- 不发送电子邮件通知9 f2 u& ]# F0 ~( {6 R
@notify_level_netsend = 0, -- 不发送网络消息通知
+ S- A* n5 M9 p ~9 | @notify_level_page = 0, -- 不发送寻呼通知% }9 e( Q+ l5 a, U3 S2 G
@delete_level = 0, -- 不自动删除作业- `/ G6 l( d$ @" ~! O
@description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述# c' }/ w" e( V8 Z) h3 u) }
@category_name = N'[Uncategorized (Local)]', -- 作业类别+ R b2 W: O* f) h8 G8 a1 C
@owner_login_name = N'YourLoginName', -- 作业所有者(请替换为实际的登录名)
) ~+ k6 I. P' {- ` @notify_email_operator_name = N''; -- 不指定电子邮件通知操作员" O3 R! ]3 R- C% _4 W) Z
GO/ P3 h6 ?7 N, ?3 Z
. K$ F; t& M* [' @$ l4 p) x-- 为作业添加一个步骤+ f- B) R) k0 \) Y3 Z! I
EXEC sp_add_jobstep 9 p# I6 B b6 X
@job_name = N'IncreaseUserCashJob', -- 作业名称# x% A' z7 ~& Y6 p* W7 O% y( z
@step_name = N'ExecuteStoredProcedure', -- 步骤名称3 C( Q9 m2 W/ z+ j( c
@subsystem = N'TSQL', -- 指定步骤使用的子系统(这里是Transact-SQL)
! f6 |6 u, a7 m6 _) Y4 s @database_name = N'account', -- 指定数据库名称
+ Q4 g# r! T$ i" v* g' S7 o @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)+ y2 ~0 X: {" \8 _
@retry_attempts = 5, -- 重试次数3 A5 f2 Z9 c( H9 r+ v$ L& e1 f
@retry_interval = 5; -- 重试间隔(分钟)6 C. j, j$ }# |6 Z
GO
: u3 W5 |+ N: p$ V
8 ?( f2 ]3 z& s. X% Z- [7 V-- 为作业添加一个每分钟执行一次的调度9 F" Z/ `7 Y# F/ ]0 E/ z
EXEC sp_add_schedule
' D- Q% ^2 L9 u! \ @schedule_name = N'MinuteSchedule', -- 调度名称
/ G( W6 K( L- B$ B3 L; h7 Y6 | @freq_type = 4, -- 频率类型(4表示每日)
+ \; z1 e0 @" ]' m C5 c @freq_interval = 1, -- 对于每日频率,这里设置为1表示每天都执行
# U) a4 ~& r& L% h% J/ I2 l9 D @freq_subday_type = 4, -- 子日频率类型(4表示分钟)
5 X0 K/ q$ H! a: Y @freq_subday_interval = 1, -- 子日频率间隔(每分钟执行一次)
) H- j% H w( r2 Y3 R @active_start_date = 20250118, -- 活动开始日期(格式YYYYMMDD)
1 G+ R1 U4 ^# j, z" n+ D @active_start_time = 0, -- 活动开始时间(以24小时制表示,0表示午夜)
4 c, A4 m1 U$ X; [0 K5 d @active_end_date = 99991231, -- 活动结束日期(通常设置为一个遥远的未来日期)
1 @' ]0 C# s- W @active_end_time = 235959; -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)
2 P7 F; H9 R/ \7 A1 m) P/ c8 EGO e& [& N: j: f; `: H7 D2 s
6 X* n+ L" \% p: J
-- 将作业与调度关联起来
# X7 H' o5 r \% T% b3 O. oEXEC sp_attach_schedule 7 [9 ?- }5 w0 _+ }
@job_name = N'IncreaseUserCashJob', -- 作业名称; f! I# d: K% C. T
@schedule_name = N'MinuteSchedule'; -- 调度名称. d5 v% o' ~3 c. K0 y
GO+ f; n* u0 o1 r
2 C2 r4 q- ]: `5 H. X. t3 j( w-- 提交作业创建到SQL Server Agent
( X5 B1 F( Z4 _$ F4 J0 \- B( PEXEC sp_add_jobserver 4 s3 K( C6 D' z* i
@job_name = N'IncreaseUserCashJob', -- 作业名称
/ m0 V% |) ?. ]' } @server_name = N'(LOCAL)'; -- 服务器名称(对于本地服务器使用'(LOCAL)')
5 n) i; R/ J7 vGO
5 G) W1 u- N8 n, ~$ t8 g4 S1 U8 h! n) O
# B( Y" L3 o" j8 E0 P0 m+ J1 `6 o7 ]
$ Z1 U( L6 F1 C
3 H( c; Y0 b% F4 k |
|