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

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

[复制链接]

2

主题

72

回帖

679

积分

高级会员

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

2

主题

72

回帖

679

积分

高级会员

积分
679
金钱
557
贡献
48
注册时间
2024-9-13
 楼主| 发表于 2025-1-18 17:04:14 | 显示全部楼层
第二步------------------首先需要SQL代理需要运行状态,在执行下面使用SQL作业计划每分钟运行一次-----------------------+ x8 R/ ~8 Y. p6 F/ s
USE msdb;
( C& ]- n0 y2 i4 X6 ~GO. E7 w: {# B* \- i2 k

6 h( G5 b! y6 d# v5 O-- 如果作业已存在,则先删除它9 D$ z! p0 ^$ a% T+ r
IF EXISTS (SELECT job_id FROM msdb.dbo.sysjobs WHERE name = N'IncreaseUserCashJob')+ Q6 _: i# d$ J; _$ I
    EXEC sp_delete_job @job_name = N'IncreaseUserCashJob';
8 g- K# S% r5 m3 EGO  y6 v3 Q6 Z/ j2 z3 G! b" U5 h( e; J2 K
9 O) x# N: J5 ~& J
-- 创建新的作业. D: N9 M5 @, r
EXEC sp_add_job
$ s# ]7 {- O$ m' E) ^0 N* P    @job_name = N'IncreaseUserCashJob',               -- 作业名称, P- {% F* @; V- P5 {9 \& z
    @enabled = 1,                                    -- 启用作业! ~1 g1 _, k3 q* J+ B' G! f
    @notify_level_eventlog = 0,                      -- 不在事件日志中记录作业状态更改
4 S, N1 l. T" }8 i/ w6 D% \. D    @notify_level_email = 0,                         -- 不发送电子邮件通知$ N9 n' a% N0 p8 m0 ]
    @notify_level_netsend = 0,                       -- 不发送网络消息通知
" h4 e  X* C8 v+ S' M    @notify_level_page = 0,                          -- 不发送寻呼通知
3 m8 T  A6 o# A1 a, x    @delete_level = 0,                               -- 不自动删除作业
# [6 _& f  w/ c$ _7 V, Y5 x    @description = N'This job increases user cash by 1 for all online users every minute.', -- 作业描述' D; u( }7 a: w4 |" v
    @category_name = N'[Uncategorized (Local)]',     -- 作业类别) _4 ?( t/ W1 L. l3 {
    @owner_login_name = N'YourLoginName',            -- 作业所有者(请替换为实际的登录名)/ L/ O0 ~- ?3 k* P  u* X0 M" x) l
    @notify_email_operator_name = N'';               -- 不指定电子邮件通知操作员
9 }) R* u: d/ P7 hGO
( R: C$ Y' X% t; _- O4 {- i: x: u+ T: d# k! K
-- 为作业添加一个步骤
! ^5 p: h* Z; OEXEC sp_add_jobstep ) g5 t8 }9 b" S3 y  ~, n- y
    @job_name = N'IncreaseUserCashJob',              -- 作业名称4 U8 G6 @( T0 r+ c' f  q. `
    @step_name = N'ExecuteStoredProcedure',         -- 步骤名称) e& p: W8 u8 Y- M' ]' ~
    @subsystem = N'TSQL',                           -- 指定步骤使用的子系统(这里是Transact-SQL)7 b. N. t; y3 `5 E* u
    @database_name = N'account',                     -- 指定数据库名称6 e& O! D4 l2 l0 r
    @command = N'EXEC dbo.IncreaseUserCashByOnlineDuration;', -- 要执行的命令(存储过程)
# Y% u, ^1 V: m    @retry_attempts = 5,                             -- 重试次数0 `$ W0 |5 [; r" U7 c
    @retry_interval = 5;                             -- 重试间隔(分钟)
0 S0 g4 [( k" P3 \+ a0 LGO
9 Q1 s! J2 Z  }8 x5 Z% N8 j* `( e& ?8 o( W4 V; l8 S. p8 g
-- 为作业添加一个每分钟执行一次的调度
2 d+ }$ B  I/ n4 V) wEXEC sp_add_schedule
4 N/ i; u5 p( N    @schedule_name = N'MinuteSchedule',             -- 调度名称3 n, B8 F' a. |8 V$ I
    @freq_type = 4,                                  -- 频率类型(4表示每日)
3 N5 a3 `4 ?' s7 x0 ?' y+ y    @freq_interval = 1,                              -- 对于每日频率,这里设置为1表示每天都执行
6 a2 }# c! j  U3 p4 n$ C9 |    @freq_subday_type = 4,                           -- 子日频率类型(4表示分钟)  g+ L- G1 r8 d3 j9 \
    @freq_subday_interval = 1,                       -- 子日频率间隔(每分钟执行一次)
8 g5 @- y) ^% k6 H: D    @active_start_date = 20250118,                   -- 活动开始日期(格式YYYYMMDD)
6 M- _/ v9 p4 l! M0 X7 a    @active_start_time = 0,                          -- 活动开始时间(以24小时制表示,0表示午夜)4 p) ^: s$ {7 O, Z% G7 S
    @active_end_date = 99991231,                     -- 活动结束日期(通常设置为一个遥远的未来日期)
" U, F3 D# D! m9 `- L1 N9 b9 w    @active_end_time = 235959;                       -- 活动结束时间(以24小时制表示,235959表示一天的最后一分钟)7 U% |& J; O$ @0 k7 J5 z' ~
GO
. P3 L7 J0 p% h* k1 B5 S* J& a" H/ F9 [) q6 Y
-- 将作业与调度关联起来, U  h, n" f& R9 {5 \3 p8 g+ q" E+ o
EXEC sp_attach_schedule & p( N8 w7 V& W2 O9 n( ^
    @job_name = N'IncreaseUserCashJob',              -- 作业名称
4 |4 G# e( F, V0 E8 i    @schedule_name = N'MinuteSchedule';             -- 调度名称
7 {  g" O9 g  fGO* \8 \( J' r  @8 l# ]
, x6 M# J" ]9 B1 d( S) T# P
-- 提交作业创建到SQL Server Agent1 {7 c6 G0 `, Z# l2 C. }' i
EXEC sp_add_jobserver
; o. g& ~6 M4 B3 f1 c    @job_name = N'IncreaseUserCashJob',              -- 作业名称
. J4 ]* e. H+ c8 h! T    @server_name = N'(LOCAL)';                       -- 服务器名称(对于本地服务器使用'(LOCAL)')
' k$ W* K  v' p* b: Z' J! V. BGO
5 D5 C6 p/ \. Y* s% \- y8 p7 q, V1 D* [* Y: o: U3 f8 ]( Y
& _  j' L' `$ s
1 V) W& B1 [: Y  |1 V3 ^, I
  P0 L( |6 l+ h) @
" i" M! O5 u6 {- u2 R
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|EGameol

GMT+8, 2025-6-9 07:03 , Processed in 0.060882 second(s), 25 queries .

Powered by Discuz! X3.5

Copyright © 2001-2020, Tencent Cloud.

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