更新推荐商品逻辑
This commit is contained in:
@@ -965,6 +965,7 @@ router.get('/:id/recommended', async (req, res) => {
|
||||
categoryIds.push(...secondCategoryIds.map(item => item.id));
|
||||
|
||||
let recommendedProducts = [];
|
||||
let filteredRecommendProductIds = [];
|
||||
|
||||
// 如果有分类ID,先获取同类商品
|
||||
if (categoryIds.length > 0) {
|
||||
@@ -974,8 +975,7 @@ router.get('/:id/recommended', async (req, res) => {
|
||||
const [recommendProductIds] = await getDB().execute(recommendId, categoryIds);
|
||||
console.log(1234, recommendProductIds);
|
||||
|
||||
const filteredRecommendProductIds = [...new Set(recommendProductIds.map(item => item.product_id))];
|
||||
console.log(12345, filteredRecommendProductIds);
|
||||
filteredRecommendProductIds = [...new Set(recommendProductIds.map(item => item.product_id))];
|
||||
|
||||
// 获取同类别的其他商品作为推荐
|
||||
if (filteredRecommendProductIds.length > 0) {
|
||||
@@ -991,40 +991,23 @@ router.get('/:id/recommended', async (req, res) => {
|
||||
}
|
||||
}
|
||||
|
||||
// 如果同类别商品不足,补充其他热门商品
|
||||
// if (recommendedProducts.length < 6) {
|
||||
// const remainingCount = 6 - recommendedProducts.length;
|
||||
// const additionalQuery = `
|
||||
// SELECT id, name, price, points_price as points,
|
||||
// stock, image_url as image, description
|
||||
// FROM products
|
||||
// WHERE id NOT IN (${filteredRecommendProductIds.map(() => '?').join(',')})
|
||||
// ORDER BY RAND()
|
||||
// LIMIT ?
|
||||
// `;
|
||||
// }
|
||||
// 如果同类别商品不足,补充其他热门商品
|
||||
// if (recommendedProducts.length < 6) {
|
||||
// const remainingCount = 6 - recommendedProducts.length;
|
||||
// console.log(11111,typeof remainingCount,remainingCount);
|
||||
// if (remainingCount > 0) {
|
||||
// const additionalQuery = `
|
||||
// SELECT id, name, price, points_price as points,
|
||||
// stock, image_url as image, description
|
||||
// FROM products
|
||||
// WHERE id != ?
|
||||
// ORDER BY RAND()
|
||||
// LIMIT ?
|
||||
// `;
|
||||
|
||||
// const [additionalProducts] = await getDB().execute(
|
||||
// additionalQuery,
|
||||
// [id, remainingCount] // 现在有两个占位符:id 和 limit
|
||||
// );
|
||||
|
||||
// recommendedProducts.push(...additionalProducts);
|
||||
// }
|
||||
// }
|
||||
if (recommendedProducts.length < 6) {
|
||||
console.log(123456, filteredRecommendProductIds);
|
||||
// const remainingCount = 6 - recommendedProducts.length;
|
||||
const additionalQuery = `
|
||||
SELECT id, name, price, points_price as points,
|
||||
stock, image_url as image, description
|
||||
FROM products
|
||||
WHERE id != 3
|
||||
ORDER BY RAND()
|
||||
LIMIT ${6 - recommendedProducts.length}
|
||||
`;
|
||||
const [additionalProducts] = await getDB().execute(
|
||||
additionalQuery,
|
||||
);
|
||||
recommendedProducts.push(...additionalProducts);
|
||||
}
|
||||
|
||||
res.json({
|
||||
success: true,
|
||||
|
Reference in New Issue
Block a user