From a4998d5fc8ed96da871f8c70fe36b141cc7b5dde Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Wed, 27 Aug 2025 17:05:32 +0800 Subject: [PATCH] refactor(ai): 重构 AiMemberTalkItemService 接口并优化分页查询 --- src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java | 29 +++++++++++++++++++++++++++++ 1 files changed, 29 insertions(+), 0 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java index 7a4a121..e4a6b73 100644 --- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java @@ -2,18 +2,29 @@ import cc.mrbird.febs.ai.entity.AiTalkItem; import cc.mrbird.febs.ai.mapper.AiTalkItemMapper; +import cc.mrbird.febs.ai.req.talk.ApiTalkItemPageDto; +import cc.mrbird.febs.ai.res.memberTalk.ApiMemberTalkItemVo; +import cc.mrbird.febs.ai.res.talk.ApiTalkItemPageVo; import cc.mrbird.febs.ai.service.AiTalkItemService; import cc.mrbird.febs.ai.utils.UUID; +import cc.mrbird.febs.common.entity.FebsResponse; import cn.hutool.core.date.DateTime; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.toolkit.Wrappers; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; +import java.util.List; + @Slf4j @Service @RequiredArgsConstructor public class AiTalkItemServiceImpl extends ServiceImpl<AiTalkItemMapper, AiTalkItem> implements AiTalkItemService { + + private final AiTalkItemMapper aiTalkItemMapper; @Override public void add(String id, int code, String context, String memberUuid, DateTime date) { AiTalkItem aiTalkItem = new AiTalkItem(); @@ -25,4 +36,22 @@ aiTalkItem.setContext(context); this.baseMapper.insert(aiTalkItem); } + + @Override + public FebsResponse historyPage(ApiTalkItemPageDto dto) { + // 创建分页对象,传入当前页和每页大小 + Page<ApiTalkItemPageVo> page = new Page<>(dto.getPageNow(), dto.getPageSize()); + Page<ApiTalkItemPageVo> pageListByQuery = aiTalkItemMapper.getPageListByQuery(page, dto); + return new FebsResponse().success().data(pageListByQuery); + } + + @Override + public List<AiTalkItem> getListByTalkId(String talkId) { + LambdaQueryWrapper<AiTalkItem> queryWrapper = Wrappers.lambdaQuery(AiTalkItem.class); + queryWrapper.eq(AiTalkItem::getTalkId, talkId); + queryWrapper.orderByDesc(AiTalkItem::getCreatedTime); + queryWrapper.last("limit 10"); + List<AiTalkItem> list = aiTalkItemMapper.selectList(queryWrapper); + return list; + } } -- Gitblit v1.9.1