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

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

[复制链接]

2

主题

75

回帖

867

积分

高级会员

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

2

主题

75

回帖

867

积分

高级会员

积分
867
金钱
728
贡献
62
注册时间
2024-9-13
 楼主| 发表于 2025-1-18 17:04:14 | 显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------
) O9 T' y8 A( ^9 [3 `) S6 `+ r. }USE msdb;' d5 G) f2 J  N6 }5 L+ R; [
GO% z/ `( N$ ~3 v

  f' ]1 a* m" i-- 如果作业已存在,则先删除它. Z& p5 _. \% d1 W  v& s% U/ g
IF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob'), Z7 C0 w1 M/ r' p0 U2 A
    EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';
2 d; a% R, i# Y4 Y( E/ Z1 PGO
! n4 Y1 W1 x. Y" K
2 r3 b9 _. h( r) `7 \+ }-- 创建新的作业
% Y& e) d( _( ^0 J0 m$ D! `' J: cEXEC sp_add_job
2 M9 E7 o! C2 o/ e6 B" G    @job_name = N'IncreaseUserCashJob',               -- 作业名称
' O- I: X- I; @2 Q( r# n3 ^    @enabled = 1,                                    -- 启用作业
" X' J3 O  b9 u: Z; y- t3 ^- U    @notify_level_eventlog = 0,                      -- 不在事件日志中记录作业状态更改
) q5 Z. c4 J0 h9 P    @notify_level_email = 0,                         -- 不发送电子邮件通知9 ^0 X% P" t8 M: v
    @notify_level_netsend = 0,                       -- 不发送网络消息通知& C5 \2 a$ K  h3 z2 e
    @notify_level_page = 0,                          -- 不发送寻呼通知
, W5 S1 Q" P1 D2 ]* Q; o0 T    @delete_level = 0,                               -- 不自动删除作业5 Y* v/ ^! K" e3 u4 s5 k" t. o: K* u5 t
    @description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述
5 |" D" l, s( G) Q3 t0 p/ ^! C  f; j    @category_name = N'[Uncategorized (Local)]',     -- 作业类别
. F+ g; r8 e7 Q0 z7 ~* W    @owner_login_name = N'YourLoginName',            -- 作业所有者(请替换为实际的登录名)$ Q# I2 @; \5 Z
    @notify_email_operator_name = N'';               -- 不指定电子邮件通知操作员; t  Q5 k  f3 L, w
GO
3 o+ u/ i5 U9 ~% o) w" O" T/ @0 |/ V4 n5 {" p+ _
-- 为作业添加一个步骤
. {1 |" j# P* }. @' ]EXEC sp_add_jobstep
2 H2 x9 K- f- J! C    @job_name = N'IncreaseUserCashJob',              -- 作业名称( b! h- l, v' H! V0 }7 |1 J5 G1 _( F
    @step_name = N'ExecuteStoredProcedure',         -- 步骤名称7 L: T# p  A! ]7 Y: ^4 C
    @subsystem = N'TSQL',                           -- 指定步骤使用的子系统(这里是Transact-SQL)
" l' C8 f, {7 _& e  E1 S    @database_name = N'account',                     -- 指定数据库名称
* d$ a7 W6 D. M4 |7 g3 F; K7 C2 N    @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)
$ v$ H. \/ U( X1 N. X7 K) ~4 L" T    @retry_attempts = 5,                             -- 重试次数+ l0 l* [8 A8 y. M* W! I- Z! V- M
    @retry_interval = 5;                             -- 重试间隔(分钟)* C- g* H9 V6 U8 N) o: @" }9 `7 e/ L& J
GO
& m: J9 ]7 {) m: D3 M* i
, h4 E1 A; J2 Q! g-- 为作业添加一个每分钟执行一次的调度
( N0 h: ?0 g6 E! x8 v+ j7 ]" ?EXEC sp_add_schedule
/ u2 @- o. z+ I6 y" c7 v" n9 Z8 D# s    @schedule_name = N'MinuteSchedule',             -- 调度名称! i' ?9 C$ ~" x. c
    @freq_type = 4,                                  -- 频率类型(4表示每日)1 [( ^5 q- J* K, G# y. Q# @
    @freq_interval = 1,                              -- 对于每日频率,这里设置为1表示每天都执行. x1 @5 J" v4 ^9 }' I- p1 S
    @freq_subday_type = 4,                           -- 子日频率类型(4表示分钟), P9 k" ~" P+ X& M$ {9 v+ i
    @freq_subday_interval = 1,                       -- 子日频率间隔(每分钟执行一次)
% @' u6 U/ Y: L8 A* B    @active_start_date = 20250118,                   -- 活动开始日期(格式YYYYMMDD)" R2 o$ A3 A7 E; Y4 J, L
    @active_start_time = 0,                          -- 活动开始时间(以24小时制表示,0表示午夜)- h; o( `$ ^) F. P
    @active_end_date = 99991231,                     -- 活动结束日期(通常设置为一个遥远的未来日期)
! D# S1 x9 Z$ N+ \2 J9 ^    @active_end_time = 235959;                       -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)
. \  ]. N0 k0 c; KGO5 S8 M5 U9 k# p% o8 V. Z2 l7 Q

7 c1 z9 o  ^: y: |9 [-- 将作业与调度关联起来
( h7 d# E+ O  C  |EXEC sp_attach_schedule 7 U' G7 }! t* S3 i3 }
    @job_name = N'IncreaseUserCashJob',              -- 作业名称8 v" q+ y; K2 H7 `& p) u3 b0 |
    @schedule_name = N'MinuteSchedule';             -- 调度名称- a: s$ K- G" O7 z$ A
GO) w! [9 l: P- O
% F! a6 O7 M* j4 H7 D+ e
-- 提交作业创建到SQL Server Agent( J5 B  N) U6 }- x" N
EXEC sp_add_jobserver ; E! I0 N$ w% o8 x
    @job_name = N'IncreaseUserCashJob',              -- 作业名称
$ t, P: k+ h. g' n# D( Q9 T3 f    @server_name = N'(LOCAL)';                       -- 服务器名称(对于本地服务器使用'(LOCAL)')
( _" @4 T3 q( C$ v3 q8 @& i* fGO
8 J, `" |8 z2 T# G5 f/ G3 X2 c9 x- q  c9 B  k  u* U3 x& r

% [9 t1 H% l  }& `; j3 G  C
& @9 [& @1 A# k& ]5 a$ ]$ X) N1 l# D1 P7 T. k7 L

+ ^7 c4 \1 n/ D, m
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则


Archiver|小黑屋|EGameol

GMT+8, 2026-2-28 21:20 , Processed in 0.070440 second(s), 29 queries .

Powered by Discuz! X3.5

Copyright © 2001-2020, Tencent Cloud.

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