go-common/app/service/live/xlottery/dao/coin_config.go
2019-04-22 18:49:16 +08:00

114 lines
3.7 KiB
Go

package dao
import (
"context"
"fmt"
"strconv"
"strings"
v1pb "go-common/app/service/live/xlottery/api/grpc/v1"
"go-common/app/service/live/xlottery/model"
"go-common/library/database/sql"
"go-common/library/log"
)
const (
_getCoinConfig = "SELECT coin_id, type, area_v2_parent_id, area_v2_id, gift_id FROM capsule_coin_config WHERE coin_id = ? AND status = 1 "
_getCoinConfigMap = "SELECT coin_id, type, area_v2_parent_id, area_v2_id, gift_id FROM capsule_coin_config WHERE coin_id in (%v) AND status = 1"
_updateCoinConfig = "UPDATE capsule_coin_config SET status = ? WHERE coin_id = ?"
_addCoinConfig = "INSERT INTO capsule_coin_config (type,gift_id,area_v2_parent_id,area_v2_id,coin_id,status) VALUES "
)
//GetCoinConfig 获取扭蛋币配置
func (d *Dao) GetCoinConfig(ctx context.Context, coinId int64) (configs []*model.CoinConfig, err error) {
var rows *sql.Rows
if rows, err = d.db.Query(ctx, _getCoinConfig, coinId); err != nil {
log.Error("[dao.coin_config | GetCoinConfig]query(%s) error(%v)", _getCoinConfig, err)
return
}
defer rows.Close()
configs = make([]*model.CoinConfig, 0)
for rows.Next() {
d := &model.CoinConfig{}
if err = rows.Scan(&d.CoinId, &d.Type, &d.AreaV2ParentId, &d.AreaV2Id, &d.GiftId); err != nil {
log.Error("[dao.coin_config | GetCoinConfig] scan error, err %v", err)
return
}
configs = append(configs, d)
}
return
}
//GetCoinConfigMap 批量获取扭蛋币
func (d *Dao) GetCoinConfigMap(ctx context.Context, coinIds []int64) (configMap map[int64][]*model.CoinConfig, err error) {
var rows *sql.Rows
stringCoinIds := make([]string, 0)
for _, coinId := range coinIds {
stringCoinIds = append(stringCoinIds, strconv.FormatInt(coinId, 10))
}
coinString := strings.Join(stringCoinIds, ",")
if rows, err = d.db.Query(ctx, fmt.Sprintf(_getCoinConfigMap, coinString)); err != nil {
log.Error("[dao.coin_config | GetCoinConfigMap]query(%s) error(%v)", _getCoinConfigMap, err)
return
}
defer rows.Close()
configMap = make(map[int64][]*model.CoinConfig)
for rows.Next() {
d := &model.CoinConfig{}
if err = rows.Scan(&d.CoinId, &d.Type, &d.AreaV2ParentId, &d.AreaV2Id, &d.GiftId); err != nil {
log.Error("[dao.coin_config | GetCoinConfigMap] scan error, err %v", err)
return
}
if _, ok := configMap[d.CoinId]; !ok {
configMap[d.CoinId] = make([]*model.CoinConfig, 0)
}
configMap[d.CoinId] = append(configMap[d.CoinId], d)
}
return
}
//UpdateCoinConfig 更新扭蛋币配置
func (d *Dao) UpdateCoinConfig(ctx context.Context, coinId int64, areaIds []*v1pb.UpdateCoinConfigReq_AreaIds, giftIds []int64) (status bool, err error) {
_, err = d.db.Exec(ctx, _updateCoinConfig, 2, coinId)
if err != nil {
log.Error("[dao.coin_config | UpdateCoinConfig] query(%s) error(%v)", _updateCoinConfig, err)
return
}
rowFields := make([][6]interface{}, 0)
for _, giftId := range giftIds {
rowFields = append(rowFields, [6]interface{}{2, giftId, 0, 0, coinId, 1})
}
if len(areaIds) != 0 {
for _, areaId := range areaIds {
if areaId.IsAll == 1 {
rowFields = append(rowFields, [6]interface{}{1, 0, areaId.ParentId, areaId.ParentId, coinId, 1})
} else {
for _, areaV2Id := range areaId.List {
rowFields = append(rowFields, [6]interface{}{1, 0, areaId.ParentId, areaV2Id, coinId, 1})
}
}
}
}
sqlStr := _addCoinConfig + strings.Repeat("(?,?,?,?,?,?),", len(rowFields))
slen := len(sqlStr) - 1
sqlStr = sqlStr[0:slen]
values := make([]interface{}, len(rowFields)*6)
for i, field := range rowFields {
for j, v := range field {
ix := i*6 + j
values[ix] = v
}
}
res, err := d.db.Exec(ctx, sqlStr, values...)
if err != nil {
log.Error("[dao.coin_config | UpdateCoinConfig] insert(%s) error(%v)", sqlStr, err)
return
}
rows, _ := res.RowsAffected()
status = rows > 0
return
}