123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- package dataexport
- import (
- qutil "app.yhyue.com/moapp/jybase/common"
- "app.yhyue.com/moapp/jybase/mysql"
- "fmt"
- "strings"
- )
- // GetLastExportPhoneAndMail 数据导出联想上次导出手机号和邮箱查询
- func GetLastExportPhoneAndMail(mysqlSess *mysql.Mysql, userId, entUserId string) (phone, email string) {
- var searchSql []string
- var searchValue []interface{}
- if userId != "" {
- //个人直接支付数据导出
- searchSql = append(searchSql, `(SELECT user_phone AS phone,user_mail AS mail,UNIX_TIMESTAMP(create_time) AS exportDate FROM dataexport_order where user_mail IS NOT NULL and user_phone is NOT NULL AND user_id =? AND product_type ='历史数据' ORDER BY create_time DESC LIMIT 1)`)
- searchValue = append(searchValue, userId)
- //每日限量包和个人线上数据包
- searchSql = append(searchSql, `(SELECT phone,mail,date AS exportDate FROM datapacket_record WHERE phone IS NOT NULL AND mail IS NOT NULL AND useid = ? ORDER BY id DESC LIMIT 1)`)
- searchValue = append(searchValue, userId)
- }
- //企业数据导出查询
- if entUserId != "" {
- searchSql = append(searchSql, `(SELECT export_phone AS phone,export_mail AS mail,UNIX_TIMESTAMP(export_time) AS exportDate FROM entniche_export_log WHERE export_phone IS NOT NULL AND export_mail IS NOT NULL AND user_id =? ORDER BY id desc limit 1)`)
- searchValue = append(searchValue, entUserId)
- }
- //log.Println(fmt.Sprintf(`SELECT phone,mail FROM ( %s ) AS allData ORDER BY exportDate DESC limit 1`, strings.Join(searchSql, ` UNION ALL `)))
- res := mysqlSess.Query(fmt.Sprintf(`SELECT phone,mail FROM ( %s ) AS allData ORDER BY exportDate DESC limit 1`, strings.Join(searchSql, ` UNION ALL `)), searchValue...)
- if res != nil && len(*res) > 0 {
- phone, _ = (*res)[0]["phone"].(string)
- email, _ = (*res)[0]["mail"].(string)
- }
- return
- }
- // GetDataExportMatchKey key 关键词 逗号分隔 或的关系进行关联 types 匹配类型 data数据
- // title 标题,detail 正文,filetext 附件,purchasing 标的物,projectname.pname 项目命,mbuyer 采购单位,mwinner 中标单位,magency 代理机构
- func GetDataExportMatchKey(scd *SieveCondition, list *[]map[string]interface{}) {
- if list == nil || len(*list) == 0 {
- return
- }
- if scd.Comeinfrom == "pushHistory" { //历史推送数据使用推送匹配关键词 if len(scd.PushKeyWords) == len(*list) {
- for _, v := range *list {
- for k, v1 := range scd.SelectIds {
- if v1 == qutil.InterfaceToStr(v["_id"]) {
- v["keyword"] = scd.PushKeyWords[k]
- }
- }
- //v["keyword"] = scd.PushKeyWords[qutil.InterfaceToStr(v["_id"])]
- }
- } else if len(scd.Keyword) > 0 { //关键词二次匹配
- types := scd.SelectType
- var keys []string
- //统计关键词
- for _, vk := range scd.Keyword {
- key := []string{}
- for _, v := range strings.Split(vk.Keyword, " ") {
- if v != "" {
- key = append(key, v)
- }
- }
- if len(vk.Appended) > 0 {
- for _, v := range vk.Appended {
- if v != "" {
- key = append(key, strings.Split(v, " ")...)
- }
- }
- }
- vk.Keyword = strings.Join(key, ",")
- keys = append(keys, strings.ReplaceAll(vk.Keyword, "+", ","))
- }
- key := strings.Join(keys, ",")
- if key != "" {
- //二次匹配
- for _, data := range *list {
- keyWord := []string{}
- if strings.Contains(types, "title") {
- title := qutil.ObjToString(data["title"])
- keyWord = KeyWordToDatas(title, key, keyWord)
- }
- if strings.Contains(types, "detail") {
- detail := qutil.ObjToString(data["detail"])
- keyWord = KeyWordToDatas(detail, key, keyWord)
- }
- if strings.Contains(types, "purchasing") {
- purchasing := qutil.ObjToString(data["purchasing"])
- keyWord = KeyWordToDatas(purchasing, key, keyWord)
- }
- if strings.Contains(types, "filetext") {
- filetext := qutil.ObjToString(data["filetext"])
- keyWord = KeyWordToDatas(filetext, key, keyWord)
- }
- if strings.Contains(types, "projectname.pname") {
- projectname := qutil.ObjToString(data["projectname"])
- keyWord = KeyWordToDatas(projectname, key, keyWord)
- }
- if strings.Contains(types, "buyer.mbuyer") {
- buyer := qutil.ObjToString(data["buyer"])
- keyWord = KeyWordToDatas(buyer, key, keyWord)
- }
- if strings.Contains(types, "s_winner.mwinner") {
- winner := qutil.ObjToString(data["s_winner"])
- keyWord = KeyWordToDatas(winner, key, keyWord)
- }
- if strings.Contains(types, "agency.magency") {
- winner := qutil.ObjToString(data["agency"])
- keyWord = KeyWordToDatas(winner, key, keyWord)
- }
- keyMap := map[string]bool{}
- keyArr := []string{}
- for _, key1 := range keyWord {
- keyMap[key1] = true
- }
- for k, _ := range keyMap {
- keyArr = append(keyArr, k)
- }
- data["keyword"] = strings.Join(keyArr, ",")
- }
- }
- }
- }
- func KeyWordToDatas(item, key string, keyWord []string) []string {
- for _, mk := range strings.Split(key, ",") {
- if strings.Contains(mk, "&&") {
- arr := strings.Split(mk, "&&")
- for _, s := range arr {
- if s != "" {
- if strings.Contains(strings.ToUpper(item), strings.ToUpper(s)) {
- keyWord = append(keyWord, mk)
- }
- }
- }
- } else {
- if strings.Contains(strings.ToUpper(item), strings.ToUpper(mk)) {
- keyWord = append(keyWord, mk)
- }
- }
- }
- return keyWord
- }
- // 获取关键词匹配字段
- func getKeywordFields() {
- }
|