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

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

[复制链接]

2

主题

75

回帖

854

积分

高级会员

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

2

主题

75

回帖

854

积分

高级会员

积分
854
金钱
716
贡献
61
注册时间
2024-9-13
 楼主| 发表于 2025-1-18 17:04:14 | 显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------
% m0 w+ t1 F, X7 K2 |USE msdb;0 t0 H' y" w/ a$ {; j- U
GO! P3 S* c9 U4 r" o; N$ ?

3 E/ s3 z+ f7 N5 P-- 如果作业已存在,则先删除它& Y$ k: M5 V1 `9 w/ Y% g3 l
IF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')
/ }: h7 w5 ~+ C5 Q    EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';& T( v" E, Y& R+ _1 G
GO
. C! N4 j4 p/ V8 ~9 u% Z6 [
* T3 d! Z. u4 E8 [- O, U-- 创建新的作业9 j) v3 t: p  h( P+ [; j7 a: v
EXEC sp_add_job
$ j* U9 J6 l" w# K) r& t    @job_name = N'IncreaseUserCashJob',               -- 作业名称
( h: u1 O( B6 N- W% z( T    @enabled = 1,                                    -- 启用作业  ~! C9 A; |& x/ C- q
    @notify_level_eventlog = 0,                      -- 不在事件日志中记录作业状态更改
$ G' U; x. e) T) l7 y    @notify_level_email = 0,                         -- 不发送电子邮件通知
: v# j$ d1 r" z( T$ V* O1 d    @notify_level_netsend = 0,                       -- 不发送网络消息通知+ i, k9 O/ @, Y4 T" g! j
    @notify_level_page = 0,                          -- 不发送寻呼通知. J- ?( m' ^$ p, v1 {3 Y
    @delete_level = 0,                               -- 不自动删除作业
0 m2 Q8 e0 A, L7 t0 H; X3 h- t    @description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述
9 v; x) y1 `/ W1 C* [! o1 n6 ?    @category_name = N'[Uncategorized (Local)]',     -- 作业类别5 ]+ R4 P+ z7 Y! m7 Y& f7 R6 c% B
    @owner_login_name = N'YourLoginName',            -- 作业所有者(请替换为实际的登录名): y3 `/ z' g. S1 Y/ t$ q2 C& W
    @notify_email_operator_name = N'';               -- 不指定电子邮件通知操作员
0 k7 g( h9 g3 k$ TGO
; J! P: K0 Z- c! U, D+ q- Y+ G# F. }0 |$ k
-- 为作业添加一个步骤
3 r# t7 e* f/ E& f, A$ f& l5 tEXEC sp_add_jobstep
- u$ H, o$ c9 w* h7 n. L    @job_name = N'IncreaseUserCashJob',              -- 作业名称4 |) N1 v7 @/ ^9 z' `3 M* t
    @step_name = N'ExecuteStoredProcedure',         -- 步骤名称
4 h$ ]7 ~% g/ _' j    @subsystem = N'TSQL',                           -- 指定步骤使用的子系统(这里是Transact-SQL)
2 x& Y8 n, F4 R    @database_name = N'account',                     -- 指定数据库名称* E2 R) m* B$ o
    @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)' P$ u) C/ q9 H; ~8 @! s
    @retry_attempts = 5,                             -- 重试次数
' U0 v/ G  |4 t# ]! o! r8 e    @retry_interval = 5;                             -- 重试间隔(分钟)
  z9 L7 g! ^5 }9 O1 v" VGO
9 k+ q, u$ J- j7 }% d3 Z2 C6 t- d; o# e0 k; O* x. d+ q" C
-- 为作业添加一个每分钟执行一次的调度. r: S& U  }  A' j/ i5 z
EXEC sp_add_schedule
8 p5 E* y1 b; g0 c+ Y    @schedule_name = N'MinuteSchedule',             -- 调度名称
) c/ O9 h2 l/ B  l- A* d    @freq_type = 4,                                  -- 频率类型(4表示每日)( Q' T! @7 z2 @
    @freq_interval = 1,                              -- 对于每日频率,这里设置为1表示每天都执行! z7 r! m# S. u( i
    @freq_subday_type = 4,                           -- 子日频率类型(4表示分钟)
4 L+ ^7 C, h8 {$ A2 J% k    @freq_subday_interval = 1,                       -- 子日频率间隔(每分钟执行一次)
/ {7 l# H/ [) j" j1 J# A    @active_start_date = 20250118,                   -- 活动开始日期(格式YYYYMMDD)
  K+ Q5 Z" S/ g    @active_start_time = 0,                          -- 活动开始时间(以24小时制表示,0表示午夜)8 x6 k) c; ~" l
    @active_end_date = 99991231,                     -- 活动结束日期(通常设置为一个遥远的未来日期)/ o: d, i+ [) g+ F4 X) h
    @active_end_time = 235959;                       -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)7 P+ X, ~1 b2 j7 G% L# D9 U; V
GO* O9 N, W: Z& A$ l! P

! X5 J3 f" W7 E2 M) a: D. O: O5 X-- 将作业与调度关联起来- t: A4 g8 O" r5 x, `! ~
EXEC sp_attach_schedule 9 m: O. v! G8 U5 d
    @job_name = N'IncreaseUserCashJob',              -- 作业名称
. ?- e1 M# T; S/ ^" U& s  o    @schedule_name = N'MinuteSchedule';             -- 调度名称
" P# j; K6 U4 u3 }! KGO
* a$ ]1 M$ m- [% c* e7 c# `7 m3 ~! N9 m) K
-- 提交作业创建到SQL Server Agent: F/ p+ z1 x8 n% L  @  A9 Q6 a
EXEC sp_add_jobserver
( {& @" K" ?# ?1 E. }, u- |    @job_name = N'IncreaseUserCashJob',              -- 作业名称. ?, _/ H1 a4 _0 m) U
    @server_name = N'(LOCAL)';                       -- 服务器名称(对于本地服务器使用'(LOCAL)')( [& J8 {5 h, k3 z: b; n9 f
GO1 ~% ^$ k/ P  X( J/ F3 X  c) n: @

8 }( Y5 N/ L! U* a' V/ Z  }4 b' o' s0 O4 I6 c8 r

; }4 f; s0 [8 C; S6 i4 U$ H5 X' h- s1 d+ V! r* z( m) A0 w

( k" k, g5 |& U' a# f( `6 l4 v
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则


Archiver|小黑屋|EGameol

GMT+8, 2026-1-28 16:33 , Processed in 0.063408 second(s), 28 queries .

Powered by Discuz! X3.5

Copyright © 2001-2020, Tencent Cloud.

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