This commit is contained in:
邹宗楠
2024-10-10 10:16:29 +08:00
parent 8ad9d064e3
commit 12918649cb

View File

@@ -1171,6 +1171,7 @@ func GetStoreSkusByNameIDs(db *DaoDB, storeIDs []int, nameID int) (skuList []*St
} }
func GetTopSkusByStoreIDs(db *DaoDB, storeIDs []int) (storeSkuNameExt []*StoreSkuNameExt, err error) { func GetTopSkusByStoreIDs(db *DaoDB, storeIDs []int) (storeSkuNameExt []*StoreSkuNameExt, err error) {
for _, storeId := range storeIDs {
sql := ` sql := `
SELECT t1.count, t2.id sku_id, t3.*, t1.store_id, t1.store_name SELECT t1.count, t2.id sku_id, t3.*, t1.store_id, t1.store_name
FROM( FROM(
@@ -1191,9 +1192,9 @@ func GetTopSkusByStoreIDs(db *DaoDB, storeIDs []int) (storeSkuNameExt []*StoreSk
utils.DefaultTimeValue, utils.DefaultTimeValue,
time.Now().AddDate(0, -1, 0), time.Now().AddDate(0, -1, 0),
} }
if len(storeIDs) > 0 { if storeId > 0 {
sql += " AND a.store_id IN(" + GenQuestionMarks(len(storeIDs)) + ")" sql += " AND a.store_id = ? "
sqlParams = append(sqlParams, storeIDs) sqlParams = append(sqlParams, storeId)
} }
sql += ` sql += `
AND b.sale_price > ? AND b.sale_price > ?
@@ -1212,9 +1213,9 @@ func GetTopSkusByStoreIDs(db *DaoDB, storeIDs []int) (storeSkuNameExt []*StoreSk
WHERE 1=1 WHERE 1=1
` `
sqlParams = append(sqlParams, salePriceLimit, utils.DefaultTimeValue, utils.DefaultTimeValue) sqlParams = append(sqlParams, salePriceLimit, utils.DefaultTimeValue, utils.DefaultTimeValue)
if len(storeIDs) > 0 { if storeId > 0 {
sql += " AND a.store_id IN(" + GenQuestionMarks(len(storeIDs)) + ")" sql += " AND a.store_id = ?"
sqlParams = append(sqlParams, storeIDs) sqlParams = append(sqlParams, storeId)
} }
sql += sql +=
` `
@@ -1228,17 +1229,22 @@ func GetTopSkusByStoreIDs(db *DaoDB, storeIDs []int) (storeSkuNameExt []*StoreSk
JOIN sku b ON a.sku_id = b.id AND b.deleted_at = ? AND b.status = ? JOIN sku b ON a.sku_id = b.id AND b.deleted_at = ? AND b.status = ?
JOIN sku_name c ON b.name_id = c.id AND c.deleted_at = ? AND c.status = ? JOIN sku_name c ON b.name_id = c.id AND c.deleted_at = ? AND c.status = ?
JOIN store d ON d.id = a.store_id AND d.deleted_at = ? AND d.status <> ? JOIN store d ON d.id = a.store_id AND d.deleted_at = ? AND d.status <> ?
WHERE a.store_id IN (` + GenQuestionMarks(len(storeIDs)) + `) WHERE a.store_id = ?
AND a.deleted_at = ? AND a.status = ? AND a.deleted_at = ? AND a.status = ?
ORDER BY 1 DESC ORDER BY 1 DESC
LIMIT ? LIMIT ?
` `
sqlParams = append(sqlParams, model.StoreSkuBindStatusNormal, utils.DefaultTimeValue, model.ActSkuDirectDown, model.ActSkuSecKill, sqlParams = append(sqlParams, model.StoreSkuBindStatusNormal, utils.DefaultTimeValue, model.ActSkuDirectDown, model.ActSkuSecKill,
utils.DefaultTimeValue, model.SkuStatusNormal, utils.DefaultTimeValue, model.SkuStatusNormal, utils.DefaultTimeValue, model.StoreStatusDisabled, utils.DefaultTimeValue, model.SkuStatusNormal, utils.DefaultTimeValue, model.SkuStatusNormal, utils.DefaultTimeValue, model.StoreStatusDisabled,
storeIDs, utils.DefaultTimeValue, model.StoreSkuBindStatusNormal, 30) storeId, utils.DefaultTimeValue, model.StoreSkuBindStatusNormal, 30)
err = GetRows(db, &storeSkuNameExt, sql, sqlParams...)
storeSkuName := make([]*StoreSkuNameExt, 0, 0)
err = GetRows(db, &storeSkuName, sql, sqlParams...)
var skuNamesInfo = &StoreSkuNamesInfo{ var skuNamesInfo = &StoreSkuNamesInfo{
SkuNames: storeSkuNameExt, SkuNames: storeSkuName,
}
if len(storeSkuName) != 0 {
storeSkuNameExt = append(storeSkuNameExt, storeSkuName...)
} }
var skuIdList = make([]int, 0, 0) var skuIdList = make([]int, 0, 0)
sql2 := ` sql2 := `
@@ -1254,7 +1260,7 @@ func GetTopSkusByStoreIDs(db *DaoDB, storeIDs []int) (storeSkuNameExt []*StoreSk
WHERE a.id = ? WHERE a.id = ?
AND a.deleted_at = ? AND a.deleted_at = ?
` `
for _, v := range storeSkuNameExt { for _, v := range storeSkuName {
var skus []*StoreSkuExt var skus []*StoreSkuExt
sqlParams2 := []interface{}{ sqlParams2 := []interface{}{
utils.DefaultTimeValue, utils.DefaultTimeValue,
@@ -1262,16 +1268,19 @@ func GetTopSkusByStoreIDs(db *DaoDB, storeIDs []int) (storeSkuNameExt []*StoreSk
v.SkuID, v.SkuID,
utils.DefaultTimeValue, utils.DefaultTimeValue,
} }
if len(storeIDs) > 0 { if storeId > 0 {
sql2 += " AND t4.store_id IN(" + GenQuestionMarks(len(storeIDs)) + ")" sql2 += " AND t4.store_id = ? "
sqlParams2 = append(sqlParams2, storeIDs) sqlParams2 = append(sqlParams2, storeId)
} }
if err = GetRows(db, &skus, sql2, sqlParams2...); err == nil { if err = GetRows(db, &skus, sql2, sqlParams2...); err == nil {
v.Skus = skus v.Skus = skus
skuIdList = append(skuIdList, v.SkuID) skuIdList = append(skuIdList, v.SkuID)
} }
} }
err = UpdateActPrice4StoreSkuNameNew(db, storeIDs, skuIdList, skuNamesInfo, model.VendorIDJX) err = UpdateActPrice4StoreSkuNameNew(db, []int{storeId}, skuIdList, skuNamesInfo, model.VendorIDJX)
}
return storeSkuNameExt, err return storeSkuNameExt, err
} }