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

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

[复制链接]

2

主题

75

回帖

760

积分

高级会员

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

2

主题

75

回帖

760

积分

高级会员

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

本版积分规则


Archiver|小黑屋|EGameol

GMT+8, 2025-11-8 23:26 , Processed in 0.061363 second(s), 29 queries .

Powered by Discuz! X3.5

Copyright © 2001-2020, Tencent Cloud.

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