common.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. package dataexport
  2. import (
  3. qutil "app.yhyue.com/moapp/jybase/common"
  4. "app.yhyue.com/moapp/jybase/mysql"
  5. "fmt"
  6. "strings"
  7. )
  8. // GetLastExportPhoneAndMail 数据导出联想上次导出手机号和邮箱查询
  9. func GetLastExportPhoneAndMail(mysqlSess *mysql.Mysql, userId, entUserId string) (phone, email string) {
  10. var searchSql []string
  11. var searchValue []interface{}
  12. if userId != "" {
  13. //个人直接支付数据导出
  14. 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)`)
  15. searchValue = append(searchValue, userId)
  16. //每日限量包和个人线上数据包
  17. 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)`)
  18. searchValue = append(searchValue, userId)
  19. }
  20. //企业数据导出查询
  21. if entUserId != "" {
  22. 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)`)
  23. searchValue = append(searchValue, entUserId)
  24. }
  25. //log.Println(fmt.Sprintf(`SELECT phone,mail FROM ( %s ) AS allData ORDER BY exportDate DESC limit 1`, strings.Join(searchSql, ` UNION ALL `)))
  26. res := mysqlSess.Query(fmt.Sprintf(`SELECT phone,mail FROM ( %s ) AS allData ORDER BY exportDate DESC limit 1`, strings.Join(searchSql, ` UNION ALL `)), searchValue...)
  27. if res != nil && len(*res) > 0 {
  28. phone, _ = (*res)[0]["phone"].(string)
  29. email, _ = (*res)[0]["mail"].(string)
  30. }
  31. return
  32. }
  33. // GetDataExportMatchKey key 关键词 逗号分隔 或的关系进行关联 types 匹配类型 data数据
  34. // title 标题,detail 正文,filetext 附件,purchasing 标的物,projectname.pname 项目命,mbuyer 采购单位,mwinner 中标单位,magency 代理机构
  35. func GetDataExportMatchKey(scd *SieveCondition, list *[]map[string]interface{}) {
  36. if list == nil || len(*list) == 0 {
  37. return
  38. }
  39. if scd.Comeinfrom == "pushHistory" { //历史推送数据使用推送匹配关键词 if len(scd.PushKeyWords) == len(*list) {
  40. for _, v := range *list {
  41. for k, v1 := range scd.SelectIds {
  42. if v1 == qutil.InterfaceToStr(v["_id"]) {
  43. v["keyword"] = scd.PushKeyWords[k]
  44. }
  45. }
  46. //v["keyword"] = scd.PushKeyWords[qutil.InterfaceToStr(v["_id"])]
  47. }
  48. } else if len(scd.Keyword) > 0 { //关键词二次匹配
  49. types := scd.SelectType
  50. var keys []string
  51. //统计关键词
  52. for _, vk := range scd.Keyword {
  53. key := []string{}
  54. for _, v := range strings.Split(vk.Keyword, " ") {
  55. if v != "" {
  56. key = append(key, v)
  57. }
  58. }
  59. if len(vk.Appended) > 0 {
  60. for _, v := range vk.Appended {
  61. if v != "" {
  62. key = append(key, strings.Split(v, " ")...)
  63. }
  64. }
  65. }
  66. vk.Keyword = strings.Join(key, ",")
  67. keys = append(keys, strings.ReplaceAll(vk.Keyword, "+", ","))
  68. }
  69. key := strings.Join(keys, ",")
  70. if key != "" {
  71. //二次匹配
  72. for _, data := range *list {
  73. keyWord := []string{}
  74. if strings.Contains(types, "title") {
  75. title := qutil.ObjToString(data["title"])
  76. keyWord = KeyWordToDatas(title, key, keyWord)
  77. }
  78. if strings.Contains(types, "detail") {
  79. detail := qutil.ObjToString(data["detail"])
  80. keyWord = KeyWordToDatas(detail, key, keyWord)
  81. }
  82. if strings.Contains(types, "purchasing") {
  83. purchasing := qutil.ObjToString(data["purchasing"])
  84. keyWord = KeyWordToDatas(purchasing, key, keyWord)
  85. }
  86. if strings.Contains(types, "filetext") {
  87. filetext := qutil.ObjToString(data["filetext"])
  88. keyWord = KeyWordToDatas(filetext, key, keyWord)
  89. }
  90. if strings.Contains(types, "projectname.pname") {
  91. projectname := qutil.ObjToString(data["projectname"])
  92. keyWord = KeyWordToDatas(projectname, key, keyWord)
  93. }
  94. if strings.Contains(types, "buyer.mbuyer") {
  95. buyer := qutil.ObjToString(data["buyer"])
  96. keyWord = KeyWordToDatas(buyer, key, keyWord)
  97. }
  98. if strings.Contains(types, "s_winner.mwinner") {
  99. winner := qutil.ObjToString(data["s_winner"])
  100. keyWord = KeyWordToDatas(winner, key, keyWord)
  101. }
  102. if strings.Contains(types, "agency.magency") {
  103. winner := qutil.ObjToString(data["agency"])
  104. keyWord = KeyWordToDatas(winner, key, keyWord)
  105. }
  106. keyMap := map[string]bool{}
  107. keyArr := []string{}
  108. for _, key1 := range keyWord {
  109. keyMap[key1] = true
  110. }
  111. for k, _ := range keyMap {
  112. keyArr = append(keyArr, k)
  113. }
  114. data["keyword"] = strings.Join(keyArr, ",")
  115. }
  116. }
  117. }
  118. }
  119. func KeyWordToDatas(item, key string, keyWord []string) []string {
  120. for _, mk := range strings.Split(key, ",") {
  121. if strings.Contains(mk, "&&") {
  122. arr := strings.Split(mk, "&&")
  123. for _, s := range arr {
  124. if s != "" {
  125. if strings.Contains(strings.ToUpper(item), strings.ToUpper(s)) {
  126. keyWord = append(keyWord, mk)
  127. }
  128. }
  129. }
  130. } else {
  131. if strings.Contains(strings.ToUpper(item), strings.ToUpper(mk)) {
  132. keyWord = append(keyWord, mk)
  133. }
  134. }
  135. }
  136. return keyWord
  137. }
  138. // 获取关键词匹配字段
  139. func getKeywordFields() {
  140. }