go-common/app/interface/main/tv/dao/upper/load_upper.go
2019-04-22 18:49:16 +08:00

109 lines
2.9 KiB
Go

package upper
import (
"context"
"database/sql"
"fmt"
upMdl "go-common/app/interface/main/tv/model/upper"
"go-common/library/cache/memcache"
xsql "go-common/library/database/sql"
"go-common/library/ecode"
"go-common/library/log"
)
const (
_loadUpper = "SELECT id,mid,toinit,submit,ori_name,cms_name,ori_face,cms_face,valid,deleted FROM ugc_uploader WHERE mid = ?"
)
func upperMetaKey(MID int64) string {
return fmt.Sprintf("up_cms_%d", MID)
}
// LoadUpMeta loads the upper meta cms data from cache, for missed ones, pick them from the DB
func (d *Dao) LoadUpMeta(ctx context.Context, mid int64) (upper *upMdl.Upper, err error) {
if upper, err = d.upMetaCache(ctx, mid); err != nil { // mc error
log.Error("LoadUpMeta Get Mid [%d] from CMS Error (%v)", mid, err)
return
}
if upper != nil { // mc found
return
}
if upper, err = d.upMetaDB(ctx, mid); err != nil { // db error
log.Error("LoadUpMeta Get Mid ERROR (%d) (%v)", mid, err)
return
}
if upper == nil { // db not found
err = ecode.NothingFound
return
}
d.addUpMetaCache(upper) // db found, re-fill the cache
return
}
// upMetaCache get upper meta cache.
func (d *Dao) upMetaCache(c context.Context, mid int64) (upper *upMdl.Upper, err error) {
var (
key = upperMetaKey(mid)
conn = d.mc.Get(c)
item *memcache.Item
)
defer conn.Close()
if item, err = conn.Get(key); err != nil {
if err == memcache.ErrNotFound {
err = nil
missedCount.Add("tv-meta", 1)
} else {
log.Error("conn.Get(%s) error(%v)", key, err)
}
return
}
if err = conn.Scan(item, &upper); err != nil {
log.Error("conn.Get(%s) error(%v)", key, err)
}
cachedCount.Add("tv-meta", 1)
return
}
// upMetaDB gets upper meta info from DB
func (d *Dao) upMetaDB(c context.Context, mid int64) (upper *upMdl.Upper, err error) {
var row *xsql.Row
if row = d.DB.QueryRow(c, _loadUpper, mid); err != nil {
log.Error("d.db.QueryRow(%d) error(%v)", mid, err)
return
}
upper = &upMdl.Upper{}
// "SELECT id,mid,to_init,submit,ori_name,cms_name,ori_face,cms_face,valid,deleted FROM ugc_uploader WHERE mid = ?"
if err = row.Scan(&upper.ID, &upper.MID, &upper.Toinit, &upper.Submit, &upper.OriName,
&upper.CMSName, &upper.OriFace, &upper.CMSFace, &upper.Valid, &upper.Deleted); err != nil {
if err == sql.ErrNoRows {
err = nil
upper = nil
} else {
log.Error("row.Scan(mid %d) error(%v)", mid, err)
}
}
return
}
// setUpMetaCache save upMdl.Upper to memcache
func (d *Dao) setUpMetaCache(c context.Context, upper *upMdl.Upper) (err error) {
var (
key = upperMetaKey(upper.MID)
conn = d.mc.Get(c)
)
defer conn.Close()
if err = conn.Set(&memcache.Item{Key: key, Object: upper, Flags: memcache.FlagJSON, Expiration: d.mcExpire}); err != nil {
log.Error("conn.Set error(%v)", err)
return
}
return
}
// addUpMetaCache add upper meta cache
func (d *Dao) addUpMetaCache(upper *upMdl.Upper) {
d.addCache(func() {
d.setUpMetaCache(context.TODO(), upper)
})
}