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

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

[复制链接]

2

主题

75

回帖

883

积分

高级会员

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

2

主题

75

回帖

883

积分

高级会员

积分
883
金钱
742
贡献
64
注册时间
2024-9-13
发表于 2025-1-18 17:04:14 | 显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------& t+ l5 y3 `+ ^: ]( T5 m0 U
USE msdb;3 e+ V' ~9 q; Q5 p$ ^6 n
GO! D5 ^- Q# i+ N. Y3 V
3 G8 W! k- i% g9 R* I
-- 如果作业已存在,则先删除它
, o3 p$ f0 h4 F6 x, ]/ VIF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')
6 c- R+ X  \2 r# i% R    EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';  d) ^% m  h( Y3 o, w7 ]5 F+ M1 h
GO/ @4 Y/ }! S: R/ a, Z2 ]3 f  ]) f

+ J6 K) c- G2 w8 O' G-- 创建新的作业  X, L, O2 k5 E! m3 G0 m, q9 |
EXEC sp_add_job
1 b4 D$ F3 j8 e( p0 N    @job_name = N'IncreaseUserCashJob',               -- 作业名称
; f( [/ O5 j$ [8 M- `- ]  _+ k- q    @enabled = 1,                                    -- 启用作业' N5 ]  `  ~% [
    @notify_level_eventlog = 0,                      -- 不在事件日志中记录作业状态更改. |) R$ a! M% ]% c  A
    @notify_level_email = 0,                         -- 不发送电子邮件通知9 f2 u& ]# F0 ~( {6 R
    @notify_level_netsend = 0,                       -- 不发送网络消息通知
+ S- A* n5 M9 p  ~9 |    @notify_level_page = 0,                          -- 不发送寻呼通知% }9 e( Q+ l5 a, U3 S2 G
    @delete_level = 0,                               -- 不自动删除作业- `/ G6 l( d$ @" ~! O
    @description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述# c' }/ w" e( V8 Z) h3 u) }
    @category_name = N'[Uncategorized (Local)]',     -- 作业类别+ R  b2 W: O* f) h8 G8 a1 C
    @owner_login_name = N'YourLoginName',            -- 作业所有者(请替换为实际的登录名)
) ~+ k6 I. P' {- `    @notify_email_operator_name = N'';               -- 不指定电子邮件通知操作员" O3 R! ]3 R- C% _4 W) Z
GO/ P3 h6 ?7 N, ?3 Z

. K$ F; t& M* [' @$ l4 p) x-- 为作业添加一个步骤+ f- B) R) k0 \) Y3 Z! I
EXEC sp_add_jobstep 9 p# I6 B  b6 X
    @job_name = N'IncreaseUserCashJob',              -- 作业名称# x% A' z7 ~& Y6 p* W7 O% y( z
    @step_name = N'ExecuteStoredProcedure',         -- 步骤名称3 C( Q9 m2 W/ z+ j( c
    @subsystem = N'TSQL',                           -- 指定步骤使用的子系统(这里是Transact-SQL)
! f6 |6 u, a7 m6 _) Y4 s    @database_name = N'account',                     -- 指定数据库名称
+ Q4 g# r! T$ i" v* g' S7 o    @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)+ y2 ~0 X: {" \8 _
    @retry_attempts = 5,                             -- 重试次数3 A5 f2 Z9 c( H9 r+ v$ L& e1 f
    @retry_interval = 5;                             -- 重试间隔(分钟)6 C. j, j$ }# |6 Z
GO
: u3 W5 |+ N: p$ V
8 ?( f2 ]3 z& s. X% Z- [7 V-- 为作业添加一个每分钟执行一次的调度9 F" Z/ `7 Y# F/ ]0 E/ z
EXEC sp_add_schedule
' D- Q% ^2 L9 u! \    @schedule_name = N'MinuteSchedule',             -- 调度名称
/ G( W6 K( L- B$ B3 L; h7 Y6 |    @freq_type = 4,                                  -- 频率类型(4表示每日)
+ \; z1 e0 @" ]' m  C5 c    @freq_interval = 1,                              -- 对于每日频率,这里设置为1表示每天都执行
# U) a4 ~& r& L% h% J/ I2 l9 D    @freq_subday_type = 4,                           -- 子日频率类型(4表示分钟)
5 X0 K/ q$ H! a: Y    @freq_subday_interval = 1,                       -- 子日频率间隔(每分钟执行一次)
) H- j% H  w( r2 Y3 R    @active_start_date = 20250118,                   -- 活动开始日期(格式YYYYMMDD)
1 G+ R1 U4 ^# j, z" n+ D    @active_start_time = 0,                          -- 活动开始时间(以24小时制表示,0表示午夜)
4 c, A4 m1 U$ X; [0 K5 d    @active_end_date = 99991231,                     -- 活动结束日期(通常设置为一个遥远的未来日期)
1 @' ]0 C# s- W    @active_end_time = 235959;                       -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)
2 P7 F; H9 R/ \7 A1 m) P/ c8 EGO  e& [& N: j: f; `: H7 D2 s
6 X* n+ L" \% p: J
-- 将作业与调度关联起来
# X7 H' o5 r  \% T% b3 O. oEXEC sp_attach_schedule 7 [9 ?- }5 w0 _+ }
    @job_name = N'IncreaseUserCashJob',              -- 作业名称; f! I# d: K% C. T
    @schedule_name = N'MinuteSchedule';             -- 调度名称. d5 v% o' ~3 c. K0 y
GO+ f; n* u0 o1 r

2 C2 r4 q- ]: `5 H. X. t3 j( w-- 提交作业创建到SQL Server Agent
( X5 B1 F( Z4 _$ F4 J0 \- B( PEXEC sp_add_jobserver 4 s3 K( C6 D' z* i
    @job_name = N'IncreaseUserCashJob',              -- 作业名称
/ m0 V% |) ?. ]' }    @server_name = N'(LOCAL)';                       -- 服务器名称(对于本地服务器使用'(LOCAL)')
5 n) i; R/ J7 vGO
5 G) W1 u- N8 n, ~$ t8 g4 S1 U8 h! n) O

# B( Y" L3 o" j8 E0 P0 m+ J1 `6 o7 ]

$ Z1 U( L6 F1 C
3 H( c; Y0 b% F4 k
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则


Archiver|小黑屋|EGameol

GMT+8, 2026-7-5 14:45 , Processed in 0.057037 second(s), 32 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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