From ec72fc1827d3e46a99d302dd3c9ca61411c70943 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Thu, 24 Jul 2025 14:41:25 +0800
Subject: [PATCH] 修改
---
src/main/java/com/nq/service/impl/StockSubscribeServiceImpl.java | 116 ++++++++++++++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 105 insertions(+), 11 deletions(-)
diff --git a/src/main/java/com/nq/service/impl/StockSubscribeServiceImpl.java b/src/main/java/com/nq/service/impl/StockSubscribeServiceImpl.java
index 3f1e88b..b57068e 100644
--- a/src/main/java/com/nq/service/impl/StockSubscribeServiceImpl.java
+++ b/src/main/java/com/nq/service/impl/StockSubscribeServiceImpl.java
@@ -1,17 +1,27 @@
package com.nq.service.impl;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
+import com.nq.common.ResponseCode;
import com.nq.common.ServerResponse;
-import com.nq.pojo.StockSubscribe;
+import com.nq.dao.StockMapper;
+import com.nq.dao.UserPositionMapper;
+import com.nq.dao.UserStockSubscribeMapper;
+import com.nq.pojo.*;
import com.nq.service.IStockSubscribeService;
import com.nq.dao.StockSubscribeMapper;
+import com.nq.service.IUserService;
+import com.nq.vo.subscribe.StockSubscribeVO;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
+import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
+import java.util.Date;
import java.util.List;
/**
@@ -23,8 +33,16 @@
@Slf4j
public class StockSubscribeServiceImpl extends ServiceImpl<StockSubscribeMapper, StockSubscribe>
implements IStockSubscribeService {
- @Autowired
+ @Resource
StockSubscribeMapper stockSubscribeMapper;
+
+ @Autowired
+ UserStockSubscribeMapper userStockSubscribeMapper;
+
+ @Autowired
+ UserPositionMapper userPositionMapper;
+ @Autowired
+ IUserService iUserService;
/**
* @Description: 用户新股列表
@@ -34,7 +52,7 @@
* @Date: 2022/10/25
*/
@Override
- public ServerResponse list(String name, String code, Integer zt, Integer isLock, Integer type, HttpServletRequest request) {
+ public ServerResponse list(String name, String code, Integer zt,Integer getType, Integer isLock, Integer type, Integer stockType,Integer postType,HttpServletRequest request) {
//name和code模糊查询
QueryWrapper<StockSubscribe> queryWrapper = new QueryWrapper();
@@ -53,8 +71,28 @@
if (type != null && !type.equals("")) {
queryWrapper.eq("type", type);
}
+// if(getType == 1){
+// queryWrapper.gt("list_date", new Date());
+// }
+ if(stockType != null){
+ queryWrapper.eq("stock_type", stockType);
+ }
queryWrapper.orderByDesc("newlist_id");
+// if(postType == 0){
+// queryWrapper.select(StockSubscribe.class, info -> !info.getColumn().equals("password"));
+// }
List<StockSubscribe> stockSubscribeList = this.stockSubscribeMapper.selectList(queryWrapper);
+
+ Date newDate = new Date();
+
+ for (StockSubscribe stockSubscribe : stockSubscribeList) {
+ Date startDate = stockSubscribe.getSubscribeTime();
+ Date endDate = stockSubscribe.getSubscriptionTime();
+
+ boolean isBetween = newDate.after(startDate) && newDate.before(endDate);
+ stockSubscribe.setIsBetween(isBetween);
+ }
+
PageInfo pageInfo = new PageInfo(stockSubscribeList);
pageInfo.setList(stockSubscribeList);
@@ -72,15 +110,15 @@
public ServerResponse add(StockSubscribe model, HttpServletRequest request) {
//判断是否已经存在
log.info("model:{}", model);
- List<StockSubscribe> stockSubscribeList = this.stockSubscribeMapper.selectList(new QueryWrapper<StockSubscribe>().eq("code", model.getCode()));
- if (stockSubscribeList != null && stockSubscribeList.size() > 0) {
- return ServerResponse.createByErrorMsg("新股已经存在,不要重复添加");
+// Stock stock = stockMapper.selectOne(new LambdaQueryWrapper<Stock>().eq(Stock::getStockCode, model.getCode()).last(" limit 1"));
+// if(null == stock){
+// return ServerResponse.createByErrorMsg("新股代码不存在");
+// }
+ Long count = stockSubscribeMapper.selectCount(new LambdaQueryWrapper<StockSubscribe>()
+ .eq(StockSubscribe::getCode, model.getCode()));
+ if(count > 0){
+ return ServerResponse.createByErrorMsg("新股代码已存在");
}
-// String sinaStock = SinaStockApi.getInStockDetail(model.getCode());
-// String[] arrayOfString = sinaStock.split(",");
-// if (arrayOfString.length < 10)
-// return ServerResponse.createByErrorMsg("数据源无该新股");
- //添加新股
int resultCount = this.stockSubscribeMapper.insert(model);
if (resultCount > 0) {
return ServerResponse.createBySuccessMsg("添加新股成功");
@@ -101,8 +139,28 @@
if (stockSubscribe == null) {
return ServerResponse.createByErrorMsg("新股不存在");
}
+ Long count = stockSubscribeMapper.selectCount(new LambdaQueryWrapper<StockSubscribe>()
+ .eq(StockSubscribe::getCode, model.getCode())
+ .ne(StockSubscribe::getNewlistId,model.getNewlistId()));
+ if(count > 0){
+ return ServerResponse.createByErrorMsg("新股代码已存在");
+ }
+
//修改新股
int resultCount = this.stockSubscribeMapper.updateById(model);
+ //修改用户申购的新股代码
+ List<UserStockSubscribe> userStockSubscribes = userStockSubscribeMapper
+ .selectList(new LambdaQueryWrapper<UserStockSubscribe>()
+ .eq(UserStockSubscribe::getNewStockId, stockSubscribe.getNewlistId()));
+ for (UserStockSubscribe u : userStockSubscribes) {
+ u.setNewCode(model.getCode());
+ userStockSubscribeMapper.updateById(u);
+ }
+ List<UserPosition> userPositions = userPositionMapper.selectList(new LambdaQueryWrapper<UserPosition>().eq(UserPosition::getNewId, stockSubscribe.getNewlistId()));
+ for (UserPosition u : userPositions) {
+ u.setStockCode(model.getCode());
+ userPositionMapper.updateById(u);
+ }
if (resultCount > 0) {
return ServerResponse.createBySuccessMsg("修改新股成功");
}
@@ -130,6 +188,42 @@
return ServerResponse.createByErrorMsg("删除新股失败");
}
+ @Override
+ public ServerResponse listPageInfo(int pageNum, int pageSize, HttpServletRequest request) {
+ try {
+ /*QueryWrapper<StockSubscribe> queryWrapper = new QueryWrapper();
+ //显示 0
+ queryWrapper.eq("zt", 0);
+ queryWrapper.eq("type", 1);
+ queryWrapper.orderByDesc("list_date");
+
+ PageHelper.startPage(pageNum, pageSize);
+ List<StockSubscribe> stockSubscribeList = this.stockSubscribeMapper.selectList(queryWrapper);
+ // 获取分页信息
+ PageInfo<StockSubscribe> pageInfo = new PageInfo<>(stockSubscribeList);*/
+ User user = this.iUserService.getCurrentRefreshUser(request);
+ if (user == null) {
+ return ServerResponse.createByErrorCodeMsg(ResponseCode.NEED_LOGIN.getCode(),"请先登录", request);
+ }
+ PageHelper.startPage(pageNum, pageSize);
+ List<StockSubscribeVO> subscribeVOs = stockSubscribeMapper.selectStockSubscribeVO(0 ,1 ,user.getId());
+ PageInfo<StockSubscribeVO> pageInfo = new PageInfo<>(subscribeVOs);
+
+ Date newDate = new Date();
+ pageInfo.getList().forEach(stockSubscribe -> {
+ Date startDate = stockSubscribe.getSubscribeTime();
+ Date endDate = stockSubscribe.getSubscriptionTime();
+
+ boolean isBetween = newDate.after(startDate) && newDate.before(endDate);
+ stockSubscribe.setIsBetween(isBetween);
+ });
+ return ServerResponse.createBySuccess(pageInfo);
+ } catch (Exception e) {
+ log.error("IStockSubscribeService listPageInfo error", e);
+ }
+ return ServerResponse.createByError();
+ }
+
}
--
Gitblit v1.9.3