activity_meet_detail_log.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. package models
  2. import (
  3. "fmt"
  4. "github.com/beego/beego/v2/client/orm"
  5. "strings"
  6. "time"
  7. )
  8. //报名
  9. type CygxActivityMeetDetailLog struct {
  10. AttendanceId int `orm:"column(attendance_id);pk;"description:"主键ID"`
  11. ActivityId int `description:"活动ID"`
  12. RealName string `description:"姓名"`
  13. Mobile string `description:"手机号"`
  14. CompanyName string `description:"公司名称"`
  15. CompanyId int `description:"公司id 不在数据库的用户为0"`
  16. CreateTime time.Time `description:"创建时间"`
  17. }
  18. func GetOfflineMeetingDetailListCompanyIdStr(companyIdStr string) (item []*CygxActivityMeetDetailLog, err error) {
  19. o := orm.NewOrm()
  20. sql := `SELECT * FROM cygx_activity_offline_meeting_detail WHERE company_id IN (` + companyIdStr + `)`
  21. _, err = o.Raw(sql).QueryRows(&item)
  22. return
  23. }
  24. func GetOfflineMeetingDetailListCompanyName(companyName string) (item []*CygxActivityMeetDetailLog, err error) {
  25. o := orm.NewOrm()
  26. sql := `SELECT * FROM cygx_activity_meet_detail_log WHERE company_name IN (` + companyName + `)`
  27. _, err = o.Raw(sql).QueryRows(&item)
  28. return
  29. }
  30. //添加
  31. func AddCygxActivityMeetDetailLog(item *CygxActivityMeetDetailLog) (lastId int64, err error) {
  32. o := orm.NewOrm()
  33. lastId, err = o.Insert(item)
  34. return
  35. }
  36. func GetActivityMeetDetailLog(mobileStr string) (item []*CygxActivityMeetDetailLog, err error) {
  37. o := orm.NewOrm()
  38. sql := `SELECT * FROM cygx_activity_meet_detail_log WHERE mobile IN (` + mobileStr + `)`
  39. _, err = o.Raw(sql).QueryRows(&item)
  40. return
  41. }
  42. func GetActivityMeetDetailLogByMobile() (item []*CygxActivityMeetDetailLog, err error) {
  43. o := orm.NewOrm()
  44. sql := `SELECT * FROM cygx_activity_meet_detail_log WHERE mobile !='' GROUP BY mobile `
  45. _, err = o.Raw(sql).QueryRows(&item)
  46. return
  47. }
  48. //获取数量
  49. func GetActivityMeetDetailLogCount(condition string) (count int, err error) {
  50. o := orm.NewOrm()
  51. sqlCount := ` SELECT COUNT(1) AS count FROM cygx_activity_meet_detail_log WHERE 1=1 `
  52. if condition != "" {
  53. sqlCount += condition
  54. }
  55. err = o.Raw(sqlCount).QueryRow(&count)
  56. return
  57. }
  58. //修改公司参会数量
  59. func UpdateActivityMeetDetailLog(companyName string, num int) (err error) {
  60. sql := ` UPDATE cygx_activity_meet_detail_log SET company_meet_num= ? WHERE company_name = ?`
  61. o := orm.NewOrm()
  62. _, err = o.Raw(sql, num, companyName).Exec()
  63. return
  64. }
  65. //修改个人参会数量
  66. func UpdateActivityMeetDetailLogByUser(mobile string, num int) (err error) {
  67. sql := ` UPDATE cygx_activity_meet_detail_log SET user_meet_num= ? WHERE mobile = ?`
  68. o := orm.NewOrm()
  69. _, err = o.Raw(sql, num, mobile).Exec()
  70. return
  71. }
  72. //添加线上到会记录
  73. func AddCygxActivityMeetDetailLogOnline(list []*CygxActivityAttendanceDetail, activityId int) (err error) {
  74. o := orm.NewOrm()
  75. o.Begin()
  76. defer func() {
  77. fmt.Println(err)
  78. if err == nil {
  79. o.Commit()
  80. } else {
  81. o.Rollback()
  82. }
  83. }()
  84. var CompanyName string
  85. var MobileStr string
  86. var items []*CygxActivityMeetDetailLog
  87. //删除原有数据
  88. sql := ` DELETE FROM cygx_activity_meet_detail_log WHERE activity_id = ?`
  89. _, err = o.Raw(sql, activityId).Exec()
  90. if err != nil {
  91. return
  92. }
  93. //插入新的数据
  94. for _, v := range list {
  95. item := new(CygxActivityMeetDetailLog)
  96. item.ActivityId = v.ActivityId
  97. item.Mobile = v.Mobile
  98. item.CompanyName = v.CompanyName
  99. item.CompanyId = v.CompanyId
  100. item.CreateTime = v.CreateTime
  101. CompanyName += "'" + v.CompanyName + "',"
  102. MobileStr += v.Mobile + ","
  103. items = append(items, item)
  104. }
  105. CompanyName = strings.TrimRight(CompanyName, ",")
  106. MobileStr = strings.TrimRight(MobileStr, ",")
  107. for _, v := range items {
  108. _, err = o.Insert(v)
  109. if err != nil {
  110. return
  111. }
  112. }
  113. listCompany, err := GetOfflineMeetingDetailListCompanyName(CompanyName)
  114. if err != nil {
  115. return
  116. }
  117. //修改公司对应的数量
  118. var condition string
  119. for _, v := range listCompany {
  120. var total int
  121. condition = ` AND company_name = '` + v.CompanyName + `' `
  122. total, err = GetActivityMeetDetailLogCount(condition)
  123. if err != nil {
  124. return
  125. }
  126. sql := ` UPDATE cygx_activity_meet_detail_log SET company_meet_num= ? WHERE company_name = ?`
  127. _, err = o.Raw(sql, total, v.CompanyName).Exec()
  128. if err != nil {
  129. return
  130. }
  131. }
  132. listMobile, err := GetActivityMeetDetailLog(MobileStr)
  133. if err != nil {
  134. return
  135. }
  136. //修改个人对应的数量
  137. for _, v := range listMobile {
  138. var total int
  139. condition = ` AND mobile = '` + v.Mobile + `' `
  140. total, err = GetActivityMeetDetailLogCount(condition)
  141. if err != nil {
  142. return
  143. }
  144. sql := ` UPDATE cygx_activity_meet_detail_log SET user_meet_num= ? WHERE mobile = ?`
  145. _, err = o.Raw(sql, total, v.Mobile).Exec()
  146. if err != nil {
  147. return
  148. }
  149. }
  150. return
  151. }