高级会员
- 积分
- 679
- 金钱
- 557
- 贡献
- 48
- 注册时间
- 2024-9-13
|
楼主 |
发表于 2025-1-18 17:04:14
|
显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------+ x8 R/ ~8 Y. p6 F/ s
USE msdb;
( C& ]- n0 y2 i4 X6 ~GO. E7 w: {# B* \- i2 k
6 h( G5 b! y6 d# v5 O-- 如果作业已存在,则先删除它9 D$ z! p0 ^$ a% T+ r
IF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')+ Q6 _: i# d$ J; _$ I
EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';
8 g- K# S% r5 m3 EGO y6 v3 Q6 Z/ j2 z3 G! b" U5 h( e; J2 K
9 O) x# N: J5 ~& J
-- 创建新的作业. D: N9 M5 @, r
EXEC sp_add_job
$ s# ]7 {- O$ m' E) ^0 N* P @job_name = N'IncreaseUserCashJob', -- 作业名称, P- {% F* @; V- P5 {9 \& z
@enabled = 1, -- 启用作业! ~1 g1 _, k3 q* J+ B' G! f
@notify_level_eventlog = 0, -- 不在事件日志中记录作业状态更改
4 S, N1 l. T" }8 i/ w6 D% \. D @notify_level_email = 0, -- 不发送电子邮件通知$ N9 n' a% N0 p8 m0 ]
@notify_level_netsend = 0, -- 不发送网络消息通知
" h4 e X* C8 v+ S' M @notify_level_page = 0, -- 不发送寻呼通知
3 m8 T A6 o# A1 a, x @delete_level = 0, -- 不自动删除作业
# [6 _& f w/ c$ _7 V, Y5 x @description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述' D; u( }7 a: w4 |" v
@category_name = N'[Uncategorized (Local)]', -- 作业类别) _4 ?( t/ W1 L. l3 {
@owner_login_name = N'YourLoginName', -- 作业所有者(请替换为实际的登录名)/ L/ O0 ~- ?3 k* P u* X0 M" x) l
@notify_email_operator_name = N''; -- 不指定电子邮件通知操作员
9 }) R* u: d/ P7 hGO
( R: C$ Y' X% t; _- O4 {- i: x: u+ T: d# k! K
-- 为作业添加一个步骤
! ^5 p: h* Z; OEXEC sp_add_jobstep ) g5 t8 }9 b" S3 y ~, n- y
@job_name = N'IncreaseUserCashJob', -- 作业名称4 U8 G6 @( T0 r+ c' f q. `
@step_name = N'ExecuteStoredProcedure', -- 步骤名称) e& p: W8 u8 Y- M' ]' ~
@subsystem = N'TSQL', -- 指定步骤使用的子系统(这里是Transact-SQL)7 b. N. t; y3 `5 E* u
@database_name = N'account', -- 指定数据库名称6 e& O! D4 l2 l0 r
@command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)
# Y% u, ^1 V: m @retry_attempts = 5, -- 重试次数0 `$ W0 |5 [; r" U7 c
@retry_interval = 5; -- 重试间隔(分钟)
0 S0 g4 [( k" P3 \+ a0 LGO
9 Q1 s! J2 Z }8 x5 Z% N8 j* `( e& ?8 o( W4 V; l8 S. p8 g
-- 为作业添加一个每分钟执行一次的调度
2 d+ }$ B I/ n4 V) wEXEC sp_add_schedule
4 N/ i; u5 p( N @schedule_name = N'MinuteSchedule', -- 调度名称3 n, B8 F' a. |8 V$ I
@freq_type = 4, -- 频率类型(4表示每日)
3 N5 a3 `4 ?' s7 x0 ?' y+ y @freq_interval = 1, -- 对于每日频率,这里设置为1表示每天都执行
6 a2 }# c! j U3 p4 n$ C9 | @freq_subday_type = 4, -- 子日频率类型(4表示分钟) g+ L- G1 r8 d3 j9 \
@freq_subday_interval = 1, -- 子日频率间隔(每分钟执行一次)
8 g5 @- y) ^% k6 H: D @active_start_date = 20250118, -- 活动开始日期(格式YYYYMMDD)
6 M- _/ v9 p4 l! M0 X7 a @active_start_time = 0, -- 活动开始时间(以24小时制表示,0表示午夜)4 p) ^: s$ {7 O, Z% G7 S
@active_end_date = 99991231, -- 活动结束日期(通常设置为一个遥远的未来日期)
" U, F3 D# D! m9 `- L1 N9 b9 w @active_end_time = 235959; -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)7 U% |& J; O$ @0 k7 J5 z' ~
GO
. P3 L7 J0 p% h* k1 B5 S* J& a" H/ F9 [) q6 Y
-- 将作业与调度关联起来, U h, n" f& R9 {5 \3 p8 g+ q" E+ o
EXEC sp_attach_schedule & p( N8 w7 V& W2 O9 n( ^
@job_name = N'IncreaseUserCashJob', -- 作业名称
4 |4 G# e( F, V0 E8 i @schedule_name = N'MinuteSchedule'; -- 调度名称
7 { g" O9 g fGO* \8 \( J' r @8 l# ]
, x6 M# J" ]9 B1 d( S) T# P
-- 提交作业创建到SQL Server Agent1 {7 c6 G0 `, Z# l2 C. }' i
EXEC sp_add_jobserver
; o. g& ~6 M4 B3 f1 c @job_name = N'IncreaseUserCashJob', -- 作业名称
. J4 ]* e. H+ c8 h! T @server_name = N'(LOCAL)'; -- 服务器名称(对于本地服务器使用'(LOCAL)')
' k$ W* K v' p* b: Z' J! V. BGO
5 D5 C6 p/ \. Y* s% \- y8 p7 q, V1 D* [* Y: o: U3 f8 ]( Y
& _ j' L' `$ s
1 V) W& B1 [: Y |1 V3 ^, I
P0 L( |6 l+ h) @
" i" M! O5 u6 {- u2 R
|
|