高级会员
- 积分
- 760
- 金钱
- 630
- 贡献
- 53
- 注册时间
- 2024-9-13
|
楼主 |
发表于 2025-1-18 17:04:14
|
显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------* w8 l, c; n% I3 k
USE msdb;7 N' E; A- }3 U. y
GO
; O) L/ `; R/ o; n. E
j$ [/ l0 @( @! x/ ?) I) Q9 @$ o* m-- 如果作业已存在,则先删除它
v v# X" N6 l9 r! L: oIF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')4 p J( t: `1 K0 E
EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';
: z9 G/ @9 c5 P/ C4 D' h2 DGO8 i" \7 o+ C+ K) O+ ~7 ?
: [6 G/ ^' e5 t/ T- k# `-- 创建新的作业: s" u/ C+ i6 t
EXEC sp_add_job ! }8 z5 A+ q+ a" x$ d
@job_name = N'IncreaseUserCashJob', -- 作业名称
7 n. i4 G1 _, } @enabled = 1, -- 启用作业' g* b. t7 k2 s1 t
@notify_level_eventlog = 0, -- 不在事件日志中记录作业状态更改
* Q+ b5 R. P8 t8 j: H+ n3 Y @notify_level_email = 0, -- 不发送电子邮件通知% P: s. I, R- p8 j3 @
@notify_level_netsend = 0, -- 不发送网络消息通知4 C& I6 ]. E) A" |' v& M
@notify_level_page = 0, -- 不发送寻呼通知6 K i9 h& U, S! H. D& f8 l
@delete_level = 0, -- 不自动删除作业
) e% j; n1 g$ S' R @description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述! a7 Q4 X7 L! {6 |0 S% u7 y
@category_name = N'[Uncategorized (Local)]', -- 作业类别4 [* x A+ O; |# p
@owner_login_name = N'YourLoginName', -- 作业所有者(请替换为实际的登录名)
' n( A0 Q& r1 _- J @notify_email_operator_name = N''; -- 不指定电子邮件通知操作员. |) y3 ~" @3 Y. z0 S
GO. A( }) n" I4 t
* i7 i( @, D' z7 ~
-- 为作业添加一个步骤
7 A" C( J% z* w+ kEXEC sp_add_jobstep 7 g- i! k5 G8 s7 d; r, p: n
@job_name = N'IncreaseUserCashJob', -- 作业名称
6 H2 r, g& m2 o& ~8 X3 f1 j @step_name = N'ExecuteStoredProcedure', -- 步骤名称) O; ^" L7 G/ m
@subsystem = N'TSQL', -- 指定步骤使用的子系统(这里是Transact-SQL)7 B" {: A8 E9 p
@database_name = N'account', -- 指定数据库名称
9 I1 }4 X8 b0 G0 X6 ^6 z @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)
$ r9 i6 p; k6 Z1 l9 s9 q @retry_attempts = 5, -- 重试次数# f6 J; l6 y; ^2 N1 E' J8 R
@retry_interval = 5; -- 重试间隔(分钟)
9 t2 V' |, G- `, F3 AGO4 x( }2 A8 _( I+ r/ ?
5 ~ o H, ?2 O$ |( f* T' s4 V7 L# D-- 为作业添加一个每分钟执行一次的调度
' V2 ]" ~; |% n6 a. n8 qEXEC sp_add_schedule
4 Z' v! ^* S4 P/ q P @schedule_name = N'MinuteSchedule', -- 调度名称1 @% X7 ~# ?0 i( ]+ N7 B# I2 y3 t) X
@freq_type = 4, -- 频率类型(4表示每日)5 l/ p8 E& k' ~
@freq_interval = 1, -- 对于每日频率,这里设置为1表示每天都执行* V3 B. U6 o' @# g% q2 v
@freq_subday_type = 4, -- 子日频率类型(4表示分钟); T) o6 k( ^/ y6 w/ W4 J
@freq_subday_interval = 1, -- 子日频率间隔(每分钟执行一次)
* Q4 f( n u3 b3 o% y @active_start_date = 20250118, -- 活动开始日期(格式YYYYMMDD)
3 c$ [. C: D. C @active_start_time = 0, -- 活动开始时间(以24小时制表示,0表示午夜)
V, L$ |: m7 c) Q0 j @active_end_date = 99991231, -- 活动结束日期(通常设置为一个遥远的未来日期)
9 @! o8 ?% b1 h/ H! x' b5 \( |+ Q$ m @active_end_time = 235959; -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)
* m7 w) t p. R/ y6 s, \GO4 ^, p( {1 F! l, u1 M) V& r
7 l6 @ G/ P' I. {-- 将作业与调度关联起来) q1 H* V' X- {; H5 x7 l
EXEC sp_attach_schedule
5 n9 K9 [/ c R2 J9 W) \# \ @job_name = N'IncreaseUserCashJob', -- 作业名称
! B9 L7 Q) o2 p0 s @schedule_name = N'MinuteSchedule'; -- 调度名称* E* P5 Z" U/ v' z4 @, c: b* o0 d$ j" ^
GO
6 [6 Q# ~# e) s$ |2 m7 o! [5 D1 }. N! R
4 o' r; A1 t- `-- 提交作业创建到SQL Server Agent. w9 J: l+ ~( T! A% F
EXEC sp_add_jobserver # ^: Y. Z. X4 k, f) N
@job_name = N'IncreaseUserCashJob', -- 作业名称
3 J @6 v1 S1 v @server_name = N'(LOCAL)'; -- 服务器名称(对于本地服务器使用'(LOCAL)')
- ^+ `, h2 w0 G/ X) G( z, NGO! \$ ?9 c k8 Q* Q0 z
2 b) \/ U3 b, }. V7 b- y# W8 w
& x. ^9 u" C6 F( i4 B6 Y; U3 t' r5 | C+ H
! a+ r2 ~! I9 d1 V, ^
( G1 {5 K. v' E' R) M. _ |
|