123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 |
- package dao
- import (
- "context"
- "encoding/json"
- "fmt"
- "go-common/app/job/openplatform/open-sug/model"
- "go-common/library/database/sql"
- "go-common/library/log"
- )
- const (
- _fetchItemList = "SELECT `items_id`,`name`,`ip_right_id`,`brief`,`img` FROM `items` WHERE `status` = 1 AND `sub_status` <> 13 AND `ip_right_id` <> 0 AND `is_lastest_version` = 1 limit %d,%d"
- _fetchItem = "SELECT `items_id`,`name`,`ip_right_id`,`brief`,`img` FROM `items` WHERE `status` = 1 AND `sub_status` <> 13 AND `is_lastest_version` = 1 and `items_id` = ?"
- _fetchIPRight = "SELECT `name`,`chs_name`,`alias`,`parent_id` FROM `ip_right` WHERE `ip_right_id` = ?"
- _fetchParentIPRight = "SELECT `name`,`chs_name`,`alias` FROM `ip_right` WHERE `ip_right_id` = ?"
- _getWishCount = "SELECT COUNT(*) FROM ugc_subject_vote_%d WHERE `subject_id` = ? AND `subject_type` = 1 AND DATE(`ctime`) >= DATE_SUB(CURDATE(), INTERVAL 7 DAY)"
- _getCommentCount = "SELECT COUNT(*) FROM ugc_info_%d WHERE `subject_id` = ? AND `subject_type` = 1 AND DATE(`ctime`) >= DATE_SUB(CURDATE(), INTERVAL 7 DAY)"
- _getSaleCount = "select sum(sku_num) from (select order_id,payment_id,payment_time from order_basic where status in (3, 4, 5, 7) and parent_order_id = 0) as t1 join (select order_id,items_id,sku_id, sku_num from order_sku) as t2 on t1.order_id = t2.order_id where items_id = ? AND DATE(`ctime`) >= DATE_SUB(CURDATE(), INTERVAL 7 DAY) group by items_id "
- _fetchMatch = "SELECT `season_id`,`items_id`,`sort` FROM `sug_filter` where type = 1 and sort > 1000000000 limit %d,%d"
- _insertMatch = "INSERT INTO sug_filter (`items_id`,`season_id`,`season_name`,`sort`,`type`,`items_name`,`head_pic`,`sug_pic`) VALUES(?, ?, ?,?,'1',?,?,?)ON DUPLICATE KEY UPDATE items_name = IF(type=0, items_name,?) ,season_name = IF(type=0, season_name,?) ,sort = IF(sort>1000000000, sort,?),mtime = IF(type=0, mtime,NOW()),head_pic = IF(type=0, head_pic,?),sug_pic = IF(type=0, sug_pic,?)"
- _updatePic = "update sug_filter set sug_pic = ?,items_name = ?,head_pic =? where items_id = ? and season_id = ?"
- )
- //FetchItem query project list from mysql
- func (d *Dao) FetchItem(c context.Context) (itemList []*model.Item, err error) {
- var (
- rows *sql.Rows
- start = 0
- offset = 10
- )
- for {
- sqlStr := fmt.Sprintf(_fetchItemList, start, offset)
- start += offset
- if rows, err = d.mallDB.Query(c, sqlStr); err != nil {
- log.Error("d._fetchProjectListSQL.Query error(%v)", err)
- return
- }
- i := 0
- for rows.Next() {
- i++
- item := new(model.Item)
- var imgList string
- if err = rows.Scan(&item.ID, &item.Name, &item.IPRightID, &item.Brief, &imgList); err != nil {
- log.Error("row.Scan() error(%v)", err)
- continue
- }
- if item.Brief == "" {
- item.Brief = item.Name
- item.Name = ""
- }
- var imgListArr []string
- if err = json.Unmarshal([]byte(imgList), &imgListArr); err != nil {
- log.Error("get first img err[%s] (%v)", imgList, err)
- err = nil
- continue
- }
- item.HeadImg = imgListArr[0]
- row := d.mallDB.QueryRow(c, _fetchIPRight, item.IPRightID)
- var name, chs_name, alias, parentID, parentName, parentChsName, parentAlias string
- if err = row.Scan(&name, &chs_name, &alias, &parentID); err != nil {
- err = nil
- continue
- }
- if parentID != "0" {
- row := d.mallDB.QueryRow(c, _fetchParentIPRight, parentID)
- if err = row.Scan(&parentName, &parentChsName, &parentAlias); err != nil {
- log.Error("get parent ip_right_info err (%v)", err)
- err = nil
- continue
- }
- }
- item.Keywords = name + " " + chs_name + " " + alias + " " + parentName + " " + parentChsName + " " + parentAlias
- itemList = append(itemList, item)
- }
- if i < 10 {
- break
- }
- }
- defer rows.Close()
- err = rows.Err()
- return
- }
- // GetBind select sug from db
- func (d *Dao) GetBind(c context.Context) (sugList []*model.Sug, err error) {
- var (
- rows *sql.Rows
- start = 0
- offset = 50
- )
- for {
- sqlStr := fmt.Sprintf(_fetchMatch, start, offset)
- start += offset
- if rows, err = d.ticketDB.Query(c, sqlStr); err != nil {
- log.Error("d._fetchSugListSQL.Query error(%v)", err)
- return
- }
- i := 0
- for rows.Next() {
- i++
- sug := &model.Sug{}
- sug.Item = &model.Item{}
- if err = rows.Scan(&sug.SeasonID, &sug.Item.ID, &sug.Score); err != nil {
- log.Error("row.Scan() error(%v)", err)
- continue
- }
- sugList = append(sugList, sug)
- }
- if i < 10 {
- break
- }
- }
- defer rows.Close()
- err = rows.Err()
- return
- }
- // GetItem get item info
- func (d *Dao) GetItem(c context.Context, sug *model.Sug) (err error) {
- var row *sql.Row
- if row = d.mallDB.QueryRow(c, _fetchItem, sug.Item.ID); err != nil {
- log.Error("d._fetchProjectListSQL.Query error(%v)", err)
- return
- }
- var imgList string
- if err = row.Scan(&sug.Item.ID, &sug.Item.Name, &sug.Item.IPRightID, &sug.Item.Brief, &imgList); err != nil {
- log.Error("row.Scan() error(%v)", err)
- return
- }
- if sug.Item.Brief == "" {
- sug.Item.Brief = sug.Item.Name
- sug.Item.Name = ""
- }
- var imgListArr []string
- if err = json.Unmarshal([]byte(imgList), &imgListArr); err != nil {
- log.Error("get first img err[%s] (%v)", imgList, err)
- err = nil
- return
- }
- sug.Item.HeadImg = imgListArr[0]
- row = d.mallDB.QueryRow(c, _fetchIPRight, sug.Item.IPRightID)
- var name, chs_name, alias, parentID, parentName, parentChsName, parentAlias string
- if err = row.Scan(&name, &chs_name, &alias, &parentID); err != nil {
- err = nil
- return
- }
- if parentID != "0" {
- row := d.mallDB.QueryRow(c, _fetchParentIPRight, parentID)
- if err = row.Scan(&parentName, &parentChsName, &parentAlias); err != nil {
- log.Error("get parent ip_right_info err (%v)", err)
- err = nil
- return
- }
- }
- sug.Item.Keywords = name + " " + chs_name + " " + alias + " " + parentName + " " + parentChsName + " " + parentAlias
- return
- }
|