Authored by peuei

大屏价格曲线 优化

... ... @@ -72,7 +72,7 @@
select id, skup, product_id, goods_id, storage_id, depot_num, seller_uid, price, status,
update_time, create_time
from storage_price
where skup = #{skup,jdbcType=INTEGER}
where skup = #{skup,jdbcType=INTEGER} limit 1
</select>
<update id="saleSkup" parameterType="java.lang.Integer">
update storage_price set status = 100,
... ...
... ... @@ -892,15 +892,7 @@ public class ProductServiceImpl implements ProductService {
final Integer sellerUid = storagePrice.getSellerUid();
final Integer productId = storagePrice.getProductId();
// 根据 skn 获取商品信息
Product product = productMapper.selectByPrimaryKey(productId);
if (product != null) {
// 设置商品名称
innerResult.setProductName(product.getProductName());
}
// 设置 id sku-p 和 sku-p 价格
innerResult.setId(storagePrice.getId());
innerResult.setSkup(storagePrice.getSkup());
innerResult.setSkupPrice(storagePrice.getPrice());
getProductInfoBySkn(innerResult, storagePrice, productId);
// 获取 sku-p 尺码
Storage storage = storageMapper.selectByPrimaryKey(storagePrice.getStorageId());
final Integer skuSizeId = ((storage == null) ? null : storage.getSizeId());
... ... @@ -917,6 +909,61 @@ public class ProductServiceImpl implements ProductService {
innerResult.setColorImage(ImageUrlAssist.getUrl(goodsList.get(0).getColorImage(), GOODS_IMAGE_BUCKET, null, null));
}
// 获取该 sku-p 对应 skn 下其他的 sku
getOtherSkuUnderSameSkn(innerResult, storagePrice, sellerUid, productId);
// 获取二维码
String origin = "https://o.yohobuy.com/ufo?p={skuP_storeId}&productId={skn}&skn={skn}&openby:yohobuy={\"action\":\"go.ufo\",\"params\":{\"pagename\":\"productDetail\",\"productId\":\"{skn}\"}}";
String qrCode = origin.replace("{skuP_storeId}", StringUtils.join(skuP, ",", storeId))
.replace("{skn}", Integer.toString(productId));
innerResult.setQrCode(qrCode);
// 获取价格走势
getPriceTrend(innerResult, productId, skuSizeId);
// 构建结果集并返回
result.setSkupDetail(innerResult);
return result;
}
/**
* 获取价格走势
*
* @param innerResult
* @param productId
* @param skuSizeId
*/
private void getPriceTrend(SkupDetailForScreenInfo innerResult, final Integer productId, final Integer skuSizeId) {
if (productId != null && skuSizeId != null) {
List<PriceTrendModel> priceTrendMonthList = priceTrendMonthMapper.selectByProductIdAndSizeId(productId, skuSizeId, PRICE_TREND_MONTH_DEFAULT_LIMIT);
List<PriceTrendModel> priceTrendDayList = priceTrendDayMapper.selectByProductIdAndSizeId(productId, skuSizeId, PRICE_TREND_DAY_DEFAULT_LIMIT);
// PriceTrendBO
List<PriceTrendBO> priceResultList = new ArrayList<>();
priceTrendMonthList.stream().forEach(ele -> {
PriceTrendBO bo = new PriceTrendBO();
bo.setDate(DateUtil.getDateString(ele.getCreateTime(), DateUtil.yyyy_MM_dd_HH_mm_SS));
bo.setPrice(String.valueOf(ele.getSkuPrice()));
priceResultList.add(bo);
});
// 59个0点或12点的数据 + 1个当天最近时间整点的数据
if (!priceTrendDayList.isEmpty()) {
PriceTrendBO b = new PriceTrendBO();
b.setDate(DateUtil.getDateString(priceTrendDayList.get(0).getCreateTime(), DateUtil.yyyy_MM_dd_HH_mm_SS));
b.setPrice(String.valueOf(priceTrendDayList.get(0).getSkuPrice()));
priceResultList.add(0, b);
}
// 重排一下
Collections.reverse(priceResultList);
innerResult.setPriceTrend(priceResultList);
}
}
/**
* 获取该 sku-p 对应 skn 下其他的 sku
*
* @param innerResult
* @param storagePrice
* @param sellerUid
* @param productId
*/
private void getOtherSkuUnderSameSkn(SkupDetailForScreenInfo innerResult, final StoragePrice storagePrice, final Integer sellerUid, final Integer productId) {
List<Storage> storageList = storageMapper.selectByProductId(productId);
if (!CollectionUtils.isEmpty(storageList)) {
// 过滤出所有 sku (distinct)
... ... @@ -964,68 +1011,26 @@ public class ProductServiceImpl implements ProductService {
});
innerResult.setOtherSize(innerList);
}
/*for (Storage data : storageList) {
List<StoragePrice> storagePricesList = storagePriceMapper.selectByStorageIdsPlus(Arrays.asList(data.getId()), storagePrice.getStorageId());
if (storagePricesList != null) {
SkusBO sku = new SkusBO();
Size size = sizeMapper.selectByPrimaryKey(data.getSizeId());
if (size != null) {
if (storagePricesList.size() > 0) {
// 设置其他 sku 的 ID
sku.setId(data.getId());
// 设置其他 sku 尺码
sku.setSkuSize(size.getSizeName());
// 初始化
sku.setSkuPrice(storagePricesList.get(0).getPrice());
for (StoragePrice price : storagePricesList) {
if (sku.getSkuPrice().compareTo(price.getPrice()) > 0) {
// 设置最小的 sku-p 价格为当前 sku 的价格
sku.setSkuPrice(price.getPrice());
}
}
innerList.add(sku);
}
}
}
}
innerResult.setOtherSize(innerList);*/
}
// 获取二维码
String origin = "https://o.yohobuy.com/ufo?p={skuP_storeId}&productId={skn}&skn={skn}&openby:yohobuy={\"action\":\"go.ufo\",\"params\":{\"pagename\":\"productDetail\",\"productId\":\"{skn}\"}}";
String qrCode = origin.replace("{skuP_storeId}", StringUtils.join(skuP, ",", storeId))
.replace("{skn}", Integer.toString(productId));
innerResult.setQrCode(qrCode);
/**
* 获取价格走势
* 根据 skn 获取商品信息
*
* @param innerResult
* @param storagePrice
* @param productId
*/
if (productId != null && skuSizeId != null) {
// List<PriceTrendModel> priceTrendList = priceTrendSixtyDayMapper.selectByProductIdAndSizeId(productId, skuSizeId);
List<PriceTrendModel> priceTrendMonthList = priceTrendMonthMapper.selectByProductIdAndSizeId(productId, skuSizeId, PRICE_TREND_MONTH_DEFAULT_LIMIT);
List<PriceTrendModel> priceTrendDayList = priceTrendDayMapper.selectByProductIdAndSizeId(productId, skuSizeId, PRICE_TREND_DAY_DEFAULT_LIMIT);
// PriceTrendBO
List<PriceTrendBO> priceResultList = new ArrayList<>();
priceTrendMonthList.stream().forEach(ele -> {
PriceTrendBO bo = new PriceTrendBO();
bo.setDate(DateUtil.getDateString(ele.getCreateTime(), DateUtil.yyyy_MM_dd_HH_mm_SS));
bo.setPrice(String.valueOf(ele.getSkuPrice()));
priceResultList.add(bo);
});
// 59个0点或12点的数据 + 1个当天最近时间整点的数据
if (!priceTrendDayList.isEmpty()) {
PriceTrendBO b = new PriceTrendBO();
b.setDate(DateUtil.getDateString(priceTrendDayList.get(0).getCreateTime(), DateUtil.yyyy_MM_dd_HH_mm_SS));
b.setPrice(String.valueOf(priceTrendDayList.get(0).getSkuPrice()));
priceResultList.add(0, b);
}
// 重排一下
Collections.reverse(priceResultList);
innerResult.setPriceTrend(priceResultList);
private void getProductInfoBySkn(SkupDetailForScreenInfo innerResult, final StoragePrice storagePrice, final Integer productId) {
final Product product = productMapper.selectByPrimaryKey(productId);
if (product != null) {
// 设置商品名称
innerResult.setProductName(product.getProductName());
}
// 构建结果集并返回
result.setSkupDetail(innerResult);
return result;
// 设置 id sku-p 和 sku-p 价格
innerResult.setId(storagePrice.getId());
innerResult.setSkup(storagePrice.getSkup());
innerResult.setSkupPrice(storagePrice.getPrice());
}
}
... ...