wx_user.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package models
  2. import (
  3. "eta_gn/eta_api/global"
  4. "time"
  5. )
  6. type WxUser struct {
  7. UserId int64 `gorm:"column:user_id;primaryKey;type:bigint" orm:"column(user_id);pk" gorm:"primaryKey" description:"用户ID"`
  8. Mobile string `gorm:"column:mobile;type:varchar(255)" orm:"column(mobile)" description:"手机号"`
  9. Email string `gorm:"column:email;type:varchar(255)" orm:"column(email)" description:"邮箱"`
  10. CompanyId int `gorm:"column:company_id;type:int" orm:"column(company_id)" description:"公司ID"`
  11. RealName string `gorm:"column:real_name;type:varchar(255)" orm:"column(real_name)" description:"姓名"`
  12. NickName string `gorm:"column:nick_name;type:varchar(255)" orm:"column(nick_name)" description:"昵称"`
  13. CreatedTime time.Time `gorm:"column:created_time;type:datetime" orm:"column(created_time)" description:"创建时间"`
  14. MobileTwo string `gorm:"column:mobile_two;type:varchar(255)" orm:"column(mobile_two)" description:"备用手机号"`
  15. BusinessCardUrl string `gorm:"column:business_card_url;type:varchar(255)" orm:"column(business_card_url)" description:"名片"`
  16. IsMaker int `gorm:"column:is_maker;type:int" orm:"column(is_maker)" description:"是否决策人,1:是,0:否"`
  17. Position string `gorm:"column:position;type:varchar(255)" orm:"column(position)" description:"职位"`
  18. Sex int `gorm:"column:sex;type:int" orm:"column(sex)" description:"普通用户性别,1为男性,2为女性"`
  19. DepartmentName string `gorm:"column:department_name;type:varchar(255)" orm:"column(department_name)" description:"联系人部门"`
  20. RegisterTime time.Time `gorm:"column:register_time;type:datetime" orm:"column(register_time)" description:"注册时间"`
  21. RegisterPlatform int `gorm:"column:register_platform;type:int" orm:"column(register_platform)" description:"注册平台"`
  22. Remark string `gorm:"column:remark;type:varchar(255)" orm:"column(remark)" description:"备注"`
  23. CountryCode string `gorm:"column:country_code;type:varchar(255)" orm:"column(country_code)" description:"区号,86、852、886等"`
  24. OutboundMobile string `gorm:"column:outbound_mobile;type:varchar(255)" orm:"column(outbound_mobile)" description:"外呼手机号"`
  25. OutboundCountryCode string `gorm:"column:outbound_country_code;type:varchar(255)" orm:"column(outbound_country_code)" description:"外呼手机号区号,86、852、886等"`
  26. LastUpdatedTime time.Time `gorm:"column:last_updated_time;type:datetime" orm:"column(last_updated_time)" description:"最近一次更新时间"`
  27. IsDeal int `gorm:"column:is_deal;type:int" orm:"column(is_deal)" description:"是否标记处理 0-未处理 1-已处理"`
  28. OpenId string `gorm:"column:open_id;type:varchar(255)" orm:"column(open_id)" description:"微信openid"`
  29. Headimgurl string `gorm:"column:headimgurl;type:varchar(255)" orm:"column(headimgurl)" description:"用户头像"`
  30. UserLabel string `gorm:"column:user_label;type:varchar(255)" orm:"column(user_label)" description:"查研观向用户标签"`
  31. }
  32. func GetWxUserByMobile(mobile string) (item *WxUser, err error) {
  33. sql := `SELECT * FROM wx_user WHERE mobile = ? LIMIT 1`
  34. err = global.DmSQL["weekly"].Raw(sql, mobile).First(&item).Error
  35. return
  36. }
  37. // Update 更新wxUser信息
  38. func (wxUser *WxUser) Update(cols []string) (err error) {
  39. err = global.DmSQL["weekly"].Select(cols).Updates(wxUser).Error
  40. return
  41. }
  42. // GetWxUserByCompanyIdAndMobile 根据客户ID及手机号获取用户
  43. func GetWxUserByCompanyIdAndMobile(companyId int, mobile string) (item *WxUser, err error) {
  44. sql := ` SELECT * FROM wx_user WHERE company_id = ? AND mobile = ? LIMIT 1 `
  45. err = global.DmSQL["weekly"].Raw(sql, companyId, mobile).First(&item).Error
  46. return
  47. }
  48. // DeleteWxUserAndRecordByUserId 删除用户及第三方信息
  49. func DeleteWxUserAndRecordByUserId(userId int) (err error) {
  50. to := global.DmSQL["weekly"].Begin()
  51. defer func() {
  52. if err != nil {
  53. _ = to.Rollback()
  54. } else {
  55. _ = to.Commit()
  56. }
  57. }()
  58. // 删除wx_user
  59. userSql := ` DELETE FROM wx_user WHERE user_id = ? LIMIT 1 `
  60. err = to.Exec(userSql, userId).Error
  61. // 删除user_record
  62. if err == nil {
  63. recordSql := ` DELETE FROM user_record WHERE user_id = ? `
  64. err = to.Exec(recordSql, userId).Error
  65. }
  66. return
  67. }