找回密码
 立即注册
查看: 1839|回复: 1

[技术文章] 泡点每分钟增加1商城币并实时更新商城点数,13职业端测试可用,其他未测试

[复制链接]

2

主题

75

回帖

812

积分

高级会员

积分
812
金钱
678
贡献
57
注册时间
2024-9-13
发表于 2025-1-18 17:03:06 | 显示全部楼层 |阅读模式
购买主题 本主题需向作者支付 10 贡献 才能浏览

2

主题

75

回帖

812

积分

高级会员

积分
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- }
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则


Archiver|小黑屋|EGameol

GMT+8, 2025-12-18 23:50 , Processed in 0.076096 second(s), 29 queries .

Powered by Discuz! X3.5

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表