seller.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. package models
  2. import "github.com/beego/beego/v2/client/orm"
  3. type AdminItem struct {
  4. AdminId int `description:"系统用户id"`
  5. RealName string `description:"系统用户姓名"`
  6. Mobile string `description:"手机号"`
  7. RoleType int `description:"角色类型:1需要录入指标,0:不需要"`
  8. RoleId int `description:"角色id"`
  9. RoleName string `description:"角色名称"`
  10. RoleTypeCode string `description:"角色编码"`
  11. DepartmentId int `description:"部门id"`
  12. DepartmentName string `json:"-" description:"部门名称"`
  13. GroupId int `description:"分组id"`
  14. GroupName string `json:"-" description:"分组名称"`
  15. Authority int `description:"管理权限,0:无,1:部门负责人,2:小组负责人"`
  16. OpenId string `description:"openId"`
  17. CompanyName string `description:"客户名称"`
  18. UserId int `description:"联系人id"`
  19. }
  20. func GetSellerByCompanyId(companyId int) (item *AdminItem, err error) {
  21. o := orm.NewOrmUsingDB("weekly_report")
  22. sql := ` SELECT b.*,c.open_id,c.user_id,a.company_name FROM company_product AS a
  23. INNER JOIN admin AS b ON a.seller_id=b.admin_id
  24. LEFT JOIN wx_user AS c ON b.mobile=c.mobile
  25. WHERE a.company_id=? AND role_type_code LIKE '%rai%'`
  26. err = o.Raw(sql, companyId).QueryRow(&item)
  27. return
  28. }
  29. func GetSellerByCompanyIdCheckFicc(companyId, productId int) (item *AdminItem, err error) {
  30. o := orm.NewOrmUsingDB("weekly_report")
  31. sql := ` SELECT b.*,c.open_id,c.user_id,a.company_name FROM company_product AS a
  32. INNER JOIN admin AS b ON a.seller_id=b.admin_id
  33. LEFT JOIN wx_user AS c ON b.mobile=c.mobile
  34. WHERE a.company_id=? AND a.product_id=?`
  35. err = o.Raw(sql, companyId, productId).QueryRow(&item)
  36. return
  37. }
  38. func GetSellerByName(userName string) (item *AdminItem, err error) {
  39. o := orm.NewOrmUsingDB("weekly_report")
  40. sql := ` SELECT * FROM admin WHERE real_name=? `
  41. err = o.Raw(sql, userName).QueryRow(&item)
  42. return
  43. }
  44. // 获取本组的销售ID
  45. func GetSelleridWhichGroup(companyId, productId int) (adminId string, err error) {
  46. o := orm.NewOrmUsingDB("weekly_report")
  47. sql := ` SELECT
  48. GROUP_CONCAT( DISTINCT admin_id SEPARATOR ',' ) AS adminId
  49. FROM
  50. admin
  51. WHERE
  52. group_id IN (
  53. SELECT
  54. a.group_id
  55. FROM
  56. company_product AS a
  57. INNER JOIN admin AS b ON a.seller_id = b.admin_id
  58. WHERE
  59. a.company_id = ?
  60. AND a.product_id = ?
  61. )`
  62. err = o.Raw(sql, companyId, productId).QueryRow(&adminId)
  63. return
  64. }
  65. func GetSellerByAdminId(adminId int) (item *AdminItem, err error) {
  66. o := orm.NewOrmUsingDB("weekly_report")
  67. sql := ` SELECT * FROM admin WHERE admin_id=? `
  68. err = o.Raw(sql, adminId).QueryRow(&item)
  69. return
  70. }
  71. func GetSellerByAdminMobile(mobile string) (item *AdminItem, err error) {
  72. o := orm.NewOrmUsingDB("weekly_report")
  73. sql := ` SELECT * FROM admin WHERE mobile=? `
  74. err = o.Raw(sql, mobile).QueryRow(&item)
  75. return
  76. }
  77. // GetAdminListByGroupId 根据分组id获取系统用户列表
  78. func GetAdminListByGroupId(groupId int) (items []*Admin, err error) {
  79. sql := `SELECT * FROM admin WHERE group_id=? and enabled=1 `
  80. o := orm.NewOrmUsingDB("weekly_report")
  81. _, err = o.Raw(sql, groupId).QueryRows(&items)
  82. return
  83. }
  84. // 获取权益销售信息
  85. func GetRaiSellerByCompanyId(companyId int) (item *AdminItem, err error) {
  86. o := orm.NewOrmUsingDB("weekly_report")
  87. sql := ` SELECT
  88. b.admin_id,
  89. b.real_name,
  90. b.mobile
  91. FROM
  92. company_product AS a
  93. INNER JOIN admin AS b ON a.seller_id = b.admin_id
  94. WHERE
  95. a.product_id = 2
  96. AND a.company_id = ?`
  97. err = o.Raw(sql, companyId).QueryRow(&item)
  98. return
  99. }