Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
O
operate-customer-service
概览
概览
详情
活动
周期分析
版本库
存储库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
沈振路
operate-customer-service
Commits
1966124b
提交
1966124b
authored
10月 25, 2022
作者:
沈振路
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
移动更新人群包人数方法位置
上级
c45213f7
显示空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
47 行增加
和
34 行删除
+47
-34
SchedulingTask.java
...java/com/yaoyaozw/customer/scheduling/SchedulingTask.java
+1
-34
CrowdPackageService.java
...va/com/yaoyaozw/customer/service/CrowdPackageService.java
+6
-0
CrowdPackageServiceImpl.java
...oyaozw/customer/service/impl/CrowdPackageServiceImpl.java
+40
-0
没有找到文件。
src/main/java/com/yaoyaozw/customer/scheduling/SchedulingTask.java
浏览文件 @
1966124b
...
@@ -126,39 +126,6 @@ public class SchedulingTask {
...
@@ -126,39 +126,6 @@ public class SchedulingTask {
*/
*/
// @Scheduled(cron = "0 0/15 * * * ?")
// @Scheduled(cron = "0 0/15 * * * ?")
public
void
updateCrowdPackageNumFromRedis
()
{
public
void
updateCrowdPackageNumFromRedis
()
{
localLog
.
info
(
"开始同步redis中人群包人数至数据库"
);
crowdPackageService
.
updateCrowdPackageNumFromRedis
();
HashMap
<
String
,
Integer
>
entries
=
(
HashMap
<
String
,
Integer
>)
redisTemplate
.
boundHashOps
(
CustomerCommonConstant
.
CROWD_HUMAN_NUN_REDIS_KEY
).
entries
();
if
(
CollectionUtil
.
isEmpty
(
entries
))
{
return
;
}
localLog
.
info
(
"redis中获取到人群包人数数据: {}对"
,
entries
.
size
());
Date
now
=
new
Date
();
List
<
CrowdPackage
>
list
=
crowdPackageService
.
list
();
localLog
.
info
(
"数据库中获取人群包: {}条"
,
list
.
size
());
List
<
CrowdPackage
>
resultList
=
list
.
stream
().
filter
(
item
->
entries
.
containsKey
(
item
.
getId
().
toString
()))
.
peek
(
item
->
{
item
.
setLastCountTime
(
now
);
Integer
num
=
entries
.
get
(
item
.
getId
().
toString
());
item
.
setCrowdNum
(
num
);
}).
collect
(
Collectors
.
toList
());
if
(
entries
.
size
()
!=
list
.
size
())
{
localLog
.
info
(
"删除redis在数据库中不存在的人群包"
);
List
<
String
>
idList
=
list
.
stream
().
map
(
item
->
String
.
valueOf
(
item
.
getId
())).
collect
(
Collectors
.
toList
());
for
(
String
key
:
entries
.
keySet
())
{
if
(!
idList
.
contains
(
key
))
{
localLog
.
info
(
"redis中人群包id: {} 在数据库中不存在, 删除"
,
key
);
redisTemplate
.
opsForHash
().
delete
(
CustomerCommonConstant
.
CROWD_HUMAN_NUN_REDIS_KEY
,
key
);
}
}
}
localLog
.
info
(
"要更新人群包: {} 条"
,
resultList
.
size
());
if
(
CollectionUtil
.
isNotEmpty
(
resultList
))
{
crowdPackageService
.
updateBatchById
(
resultList
);
}
localLog
.
info
(
"删除创建时的临时数据"
);
crowdPackageService
.
remove
(
new
QueryWrapper
<
CrowdPackage
>().
isNull
(
"package_name"
));
}
}
}
}
src/main/java/com/yaoyaozw/customer/service/CrowdPackageService.java
浏览文件 @
1966124b
...
@@ -99,4 +99,10 @@ public interface CrowdPackageService extends IService<CrowdPackage> {
...
@@ -99,4 +99,10 @@ public interface CrowdPackageService extends IService<CrowdPackage> {
* @return {@link BaseResult}
* @return {@link BaseResult}
*/
*/
BaseResult
updateUserPackageBatch
(
List
<
String
>
openIdList
);
BaseResult
updateUserPackageBatch
(
List
<
String
>
openIdList
);
/**
* 更新包num人群复述
*/
void
updateCrowdPackageNumFromRedis
();
}
}
src/main/java/com/yaoyaozw/customer/service/impl/CrowdPackageServiceImpl.java
浏览文件 @
1966124b
...
@@ -11,6 +11,7 @@ import com.yaoyaozw.customer.common.GenericsResult;
...
@@ -11,6 +11,7 @@ import com.yaoyaozw.customer.common.GenericsResult;
import
com.yaoyaozw.customer.components.CustomerServiceCommonAsyncComponent
;
import
com.yaoyaozw.customer.components.CustomerServiceCommonAsyncComponent
;
import
com.yaoyaozw.customer.components.TokenManager
;
import
com.yaoyaozw.customer.components.TokenManager
;
import
com.yaoyaozw.customer.constants.CrowdPackageCommonConstant
;
import
com.yaoyaozw.customer.constants.CrowdPackageCommonConstant
;
import
com.yaoyaozw.customer.constants.CustomerCommonConstant
;
import
com.yaoyaozw.customer.dto.crowd.CrowdPackageQueryDTO
;
import
com.yaoyaozw.customer.dto.crowd.CrowdPackageQueryDTO
;
import
com.yaoyaozw.customer.dto.crowd.CrowdPackageConditionDTO
;
import
com.yaoyaozw.customer.dto.crowd.CrowdPackageConditionDTO
;
import
com.yaoyaozw.customer.entity.CrowdPackage
;
import
com.yaoyaozw.customer.entity.CrowdPackage
;
...
@@ -34,6 +35,7 @@ import org.springframework.data.redis.core.RedisTemplate;
...
@@ -34,6 +35,7 @@ import org.springframework.data.redis.core.RedisTemplate;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
import
java.util.Date
;
import
java.util.Date
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.List
;
import
java.util.stream.Collectors
;
import
java.util.stream.Collectors
;
...
@@ -234,6 +236,44 @@ public class CrowdPackageServiceImpl extends ServiceImpl<MaterialCrowdPackageMap
...
@@ -234,6 +236,44 @@ public class CrowdPackageServiceImpl extends ServiceImpl<MaterialCrowdPackageMap
return
new
BaseResult
().
success
();
return
new
BaseResult
().
success
();
}
}
@Override
public
void
updateCrowdPackageNumFromRedis
()
{
LOCAL_LOG
.
info
(
"开始同步redis中人群包人数至数据库"
);
HashMap
<
String
,
Integer
>
entries
=
(
HashMap
<
String
,
Integer
>)
redisTemplate
.
boundHashOps
(
CustomerCommonConstant
.
CROWD_HUMAN_NUN_REDIS_KEY
).
entries
();
if
(
CollectionUtil
.
isEmpty
(
entries
))
{
return
;
}
LOCAL_LOG
.
info
(
"redis中获取到人群包人数数据: {}对"
,
entries
.
size
());
Date
now
=
new
Date
();
List
<
CrowdPackage
>
list
=
super
.
list
();
LOCAL_LOG
.
info
(
"数据库中获取人群包: {}条"
,
list
.
size
());
List
<
CrowdPackage
>
resultList
=
list
.
stream
().
filter
(
item
->
entries
.
containsKey
(
item
.
getId
().
toString
()))
.
peek
(
item
->
{
item
.
setLastCountTime
(
now
);
Integer
num
=
entries
.
get
(
item
.
getId
().
toString
());
item
.
setCrowdNum
(
num
);
}).
collect
(
Collectors
.
toList
());
if
(
entries
.
size
()
!=
list
.
size
())
{
LOCAL_LOG
.
info
(
"删除redis在数据库中不存在的人群包"
);
List
<
String
>
idList
=
list
.
stream
().
map
(
item
->
String
.
valueOf
(
item
.
getId
())).
collect
(
Collectors
.
toList
());
for
(
String
key
:
entries
.
keySet
())
{
if
(!
idList
.
contains
(
key
))
{
LOCAL_LOG
.
info
(
"redis中人群包id: {} 在数据库中不存在, 删除"
,
key
);
redisTemplate
.
opsForHash
().
delete
(
CustomerCommonConstant
.
CROWD_HUMAN_NUN_REDIS_KEY
,
key
);
}
}
}
LOCAL_LOG
.
info
(
"要更新人群包: {} 条"
,
resultList
.
size
());
if
(
CollectionUtil
.
isNotEmpty
(
resultList
))
{
super
.
updateBatchById
(
resultList
);
}
LOCAL_LOG
.
info
(
"删除创建时的临时数据"
);
super
.
remove
(
new
QueryWrapper
<
CrowdPackage
>().
isNull
(
"package_name"
));
}
/**
/**
* 构造操作符
* 构造操作符
*
*
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论