- step added for Change2JDSPU4Store

This commit is contained in:
gazebo
2019-01-07 09:32:06 +08:00
parent 313bd06fdc
commit cc76cd72a6
2 changed files with 73 additions and 61 deletions

View File

@@ -317,7 +317,7 @@ func Convert2JDSPU(ctx *jxcontext.Context, count int, isAsync, isContinueWhenErr
return hint, err return hint, err
} }
func Change2JDSPU4Store(ctx *jxcontext.Context, storeIDs []int, isAsync, isContinueWhenError bool) (hint string, err error) { func Change2JDSPU4Store(ctx *jxcontext.Context, storeIDs []int, step int, isAsync, isContinueWhenError bool) (hint string, err error) {
db := dao.GetDB() db := dao.GetDB()
if len(storeIDs) == 0 { if len(storeIDs) == 0 {
if err = dao.GetRows(db, &storeIDs, ` if err = dao.GetRows(db, &storeIDs, `
@@ -329,54 +329,62 @@ func Change2JDSPU4Store(ctx *jxcontext.Context, storeIDs []int, isAsync, isConti
return "", err return "", err
} }
} }
var sql string
var sqlParams []interface{}
dao.Begin(db) dao.Begin(db)
defer dao.Rollback(db) defer dao.Rollback(db)
// sql := ` if step == 1 {
// DELETE t1 sql = `
// FROM store_sku_bind t1 DELETE t1
// JOIN sku t2 ON t2.id = t1.sku_id AND t2.link_id <> 0 FROM store_sku_bind t1
// WHERE 1 = 1 JOIN sku t2 ON t2.id = t1.sku_id AND t2.link_id <> 0
// ` WHERE 1 = 1
// sqlParams := []interface{}{} `
// if len(storeIDs) > 0 { sqlParams = []interface{}{}
// sql += " AND store_id IN (" + dao.GenQuestionMarks(len(storeIDs)) + ")" if len(storeIDs) > 0 {
// sqlParams = append(sqlParams, storeIDs) sql += " AND store_id IN (" + dao.GenQuestionMarks(len(storeIDs)) + ")"
// } sqlParams = append(sqlParams, storeIDs)
// if _, err = dao.ExecuteSQL(db, sql, sqlParams...); err != nil { }
// return "", err if _, err = dao.ExecuteSQL(db, sql, sqlParams...); err != nil {
// } return "", err
}
// sql = ` sql = `
// INSERT INTO store_sku_bind(created_at, updated_at, last_operator, deleted_at, store_id, sku_id, price, unit_price, status, ebai_id, mtwm_id, jd_sync_status, ebai_sync_status, mtwm_sync_status) INSERT INTO store_sku_bind(created_at, updated_at, last_operator, deleted_at, store_id, sku_id, price, unit_price, status, ebai_id, mtwm_id, jd_sync_status, ebai_sync_status, mtwm_sync_status)
// SELECT NOW(), NOW(), ?, ?, t1.store_id, t2.id, t1.price, t1.unit_price, t1.status , 0, 0, ?, ?, ? SELECT NOW(), NOW(), ?, ?, t1.store_id, t2.id, t1.price, t1.unit_price, t1.status , 0, 0, ?, ?, ?
// FROM store_sku_bind t1 FROM store_sku_bind t1
// JOIN sku t2 ON t2.link_id = t1.sku_id AND t2.deleted_at = ? JOIN sku t2 ON t2.link_id = t1.sku_id AND t2.deleted_at = ?
// JOIN store t3 ON t3.id = t1.store_id JOIN store t3 ON t3.id = t1.store_id
// JOIN sku_name t4 ON t4.id = t2.name_id JOIN sku_name t4 ON t4.id = t2.name_id
// LEFT JOIN sku_name_place_bind t5 ON t5.place_code = t3.city_code AND t5.name_id = t4.id LEFT JOIN sku_name_place_bind t5 ON t5.place_code = t3.city_code AND t5.name_id = t4.id
// WHERE t1.deleted_at = ? AND (t4.is_global = 1 OR t5.id IS NOT NULL) AND t1.price > 0 WHERE t1.deleted_at = ? AND (t4.is_global = 1 OR t5.id IS NOT NULL) AND t1.price > 0
// ` `
// sqlParams = []interface{}{ sqlParams = []interface{}{
// ctx.GetUserName(), ctx.GetUserName(),
// utils.DefaultTimeValue, utils.DefaultTimeValue,
// // model.SkuStatusDontSale, // model.SkuStatusDontSale,
// model.SyncFlagNewMask, model.SyncFlagNewMask,
// 0, //model.SyncFlagNewMask, 0, //model.SyncFlagNewMask,
// 0, //model.SyncFlagNewMask, 0, //model.SyncFlagNewMask,
// utils.DefaultTimeValue, utils.DefaultTimeValue,
// utils.DefaultTimeValue, utils.DefaultTimeValue,
// } }
sql := ` } else if step == 2 {
UPDATE store_sku_bind t1 sql = `
JOIN sku t2 ON t2.link_id = t1.sku_id UPDATE store_sku_bind t1
SET t1.status = 0, JOIN sku t2 ON t2.link_id = t1.sku_id
t1.jd_sync_status = ? SET t1.status = 0,
WHERE t1.deleted_at = ? t1.jd_sync_status = ?
` WHERE t1.deleted_at = ?
sqlParams := []interface{}{ `
model.SyncFlagSaleMask | model.SyncFlagModifiedMask, sqlParams = []interface{}{
utils.DefaultTimeValue, model.SyncFlagSaleMask | model.SyncFlagModifiedMask,
utils.DefaultTimeValue,
}
} else {
return "", fmt.Errorf("非法的step")
} }
if len(storeIDs) > 0 { if len(storeIDs) > 0 {
sql += " AND t1.store_id IN (" + dao.GenQuestionMarks(len(storeIDs)) + ")" sql += " AND t1.store_id IN (" + dao.GenQuestionMarks(len(storeIDs)) + ")"
@@ -392,21 +400,24 @@ func Change2JDSPU4Store(ctx *jxcontext.Context, storeIDs []int, isAsync, isConti
dao.Commit(db) dao.Commit(db)
var skuIDs []int var skuIDs []int
// sql = ` if step == 1 {
// SELECT id sql = `
// FROM sku SELECT id
// WHERE link_id <> 0 AND deleted_at = ? FROM sku t1
// ` WHERE t1.link_id > 0 AND t1.deleted_at = ?
// sqlParams = []interface{}{ `
// utils.DefaultTimeValue, sqlParams = []interface{}{
// } utils.DefaultTimeValue,
sql = ` }
SELECT t1.link_id } else if step == 2 {
FROM sku t1 sql = `
WHERE t1.deleted_at = ? AND t1.link_id > 0 SELECT t1.link_id
` FROM sku t1
sqlParams = []interface{}{ WHERE t1.link_id > 0 AND t1.deleted_at = ?
utils.DefaultTimeValue, `
sqlParams = []interface{}{
utils.DefaultTimeValue,
}
} }
if err = dao.GetRows(db, &skuIDs, sql, sqlParams...); err != nil { if err = dao.GetRows(db, &skuIDs, sql, sqlParams...); err != nil {
return "", err return "", err

View File

@@ -71,6 +71,7 @@ func (c *InitDataController) Convert2JDSPU() {
// @Title 将京东商店为份的SPU转换 // @Title 将京东商店为份的SPU转换
// @Description 将京东商店为份的SPU转换 // @Description 将京东商店为份的SPU转换
// @Param token header string true "认证token" // @Param token header string true "认证token"
// @Param step formData int true "门店列表"
// @Param storeIDs formData string false "门店列表" // @Param storeIDs formData string false "门店列表"
// @Param isAsync formData bool false "是否异步操作" // @Param isAsync formData bool false "是否异步操作"
// @Param isContinueWhenError formData bool false "单个同步失败是否继续缺省false" // @Param isContinueWhenError formData bool false "单个同步失败是否继续缺省false"
@@ -81,7 +82,7 @@ func (c *InitDataController) Change2JDSPU4Store() {
c.callChange2JDSPU4Store(func(params *tInitdataChange2JDSPU4StoreParams) (retVal interface{}, errCode string, err error) { c.callChange2JDSPU4Store(func(params *tInitdataChange2JDSPU4StoreParams) (retVal interface{}, errCode string, err error) {
var storeIDs []int var storeIDs []int
if err = jxutils.Strings2Objs(params.StoreIDs, &storeIDs); err == nil { if err = jxutils.Strings2Objs(params.StoreIDs, &storeIDs); err == nil {
retVal, err = initdata.Change2JDSPU4Store(params.Ctx, storeIDs, params.IsAsync, params.IsContinueWhenError) retVal, err = initdata.Change2JDSPU4Store(params.Ctx, storeIDs, params.Step, params.IsAsync, params.IsContinueWhenError)
} }
return retVal, "", err return retVal, "", err
}) })