互动
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

82 lines
4.4 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. package models
  2. import (
  3. "github.com/ouxuanserver/osmanthuswine/src/core"
  4. "time"
  5. )
  6. const LotteryDrawRecordTableName = TableNamePrefix + "lottery_draw_record"
  7. type LotteryDrawRecord struct {
  8. Id int64 `json:"id" xorm:"pk autoincr"`
  9. ActivityId int64 `json:"activity_id" xorm:"not null comment('主活动id')"`
  10. RehearsalId int64 `json:"rehearsal_id" xorm:"not null comment('彩排id/0正式')"`
  11. UserPrizeId int64 `json:"user_prize_id" xorm:"not null comment('用户奖品id') INT(11)"`
  12. LotteryDrawActivityId int64 `json:"lottery_draw_activity_id" xorm:"not null comment('抽奖活动id')"`
  13. LotteryDrawRuleId int64 `json:"lottery_draw_rule_id" xorm:"not null comment('抽奖规则id') BIGINT(20)"`
  14. LotteryDrawRuleLadderId int64 `json:"lottery_draw_rule_ladder_id" xorm:"not null comment('规则阶梯id')"`
  15. ArchId int `json:"arch_id" xorm:"not null default 0 comment('归档id') INT(11)"`
  16. UserId int64 `json:"user_id" xorm:"not null comment('用户id')"`
  17. RollNum int `json:"roll_num" xrom:"not null default 0 comment('滚动次数') INT(11)"`
  18. UserName string `json:"user_name" description:"用户名" xorm:"not null comment('用户名')"`
  19. UserPhone string `json:"user_phone" description:"电话" xorm:"not null comment('电话号码')"`
  20. PrizeName string `json:"prize_name" description:"奖品名字" xorm:"not null comment('奖品名字')"`
  21. AreaName string `json:"area_name" description:"名字" xorm:"not null comment('地区名字')"`
  22. AreaId int64 `json:"area_id" xorm:"not null default(0) comment('地区id')"`
  23. Status int `json:"status" xorm:"not null default 0 comment('是否已经兑奖0否1是') TINYINT(1)"`
  24. Name string `json:"name" xorm:"not null default '' comment('姓名') VARCHAR(128)"`
  25. Phone string `json:"phone" xorm:"not null default '' comment('电话号码') VARCHAR(128)"`
  26. WxNo string `json:"wx_no" xorm:"not null default '' comment('微信号') VARCHAR(128)"`
  27. Address string `json:"address" xorm:"not null default '' comment('地址') VARCHAR(128)"`
  28. IsDelete bool `json:"-" xorm:"default(0)"`
  29. CreatedAt time.Time `json:"-" xorm:"created"`
  30. UpdatedAt time.Time `json:"-" xorm:"updated"`
  31. // 无关变量
  32. User *User `json:"user" xorm:"-"`
  33. LotteryDrawRuleLadder *LotteryDrawRuleLadder `json:"lottery_draw_rule_ladder" xorm:"-"`
  34. }
  35. func (t *LotteryDrawRecord) TableName() string {
  36. return LotteryDrawRecordTableName
  37. }
  38. func (t *LotteryDrawRecord) GetByUserIdAndLadderId(userId, ladderId, archId interface{}, rollNum int) (bool, error) {
  39. session := core.GetXormAuto().Where("is_delete=0 and user_id=? and lottery_draw_rule_ladder_id=? and arch_id=?",
  40. userId, ladderId, archId)
  41. defer session.Close()
  42. if rollNum > 0 {
  43. session.Where("roll_num=?", rollNum)
  44. }
  45. return session.Get(t)
  46. }
  47. func (t *LotteryDrawRecord) GetByUserPrizeId(upId int64) (bool, error) {
  48. return core.GetXormAuto().Where("is_delete=0 and user_prize_id=?", upId).Get(t)
  49. }
  50. func GetLotteryUsersResultByLotteryDrawRecord(obj, ladderId, rehearsalId interface{}, rollNum int) error {
  51. session := core.GetXormAuto().Table(new(LotteryDrawRecord)).Alias("r").
  52. Join("LEFT", new(User).Alias("u"), "u.id=r.user_id").
  53. Where("r.is_delete=0 and r.lottery_draw_rule_ladder_id=? and "+
  54. "r.rehearsal_id=?", ladderId, rehearsalId)
  55. defer session.Close()
  56. if rollNum > 0 {
  57. session = session.Where("roll_num=?", rollNum)
  58. }
  59. return session.Find(&obj)
  60. }
  61. func GetUserIdsByLotteryDrawRuleId(ruleId, rehearsalId, areaId, archId interface{}) ([]int64, error) {
  62. recordIds := make([]int64, 0)
  63. err := core.GetXormAuto().Table(new(LotteryDrawRecord)).Select("user_id").
  64. Where("lottery_draw_rule_id=? and rehearsal_id=? and area_id=? and arch_id=? and is_delete=0",
  65. ruleId, rehearsalId, areaId, archId).Find(&recordIds)
  66. return recordIds, err
  67. }
  68. func (t *LotteryDrawRecord) CountRecord(ruleId, ladderId, rehearsalId, areaId interface{}) (int64, error) {
  69. return core.GetXormAuto().Where("lottery_draw_rule_id=? and lottery_draw_rule_ladder_id=? "+
  70. "and rehearsal_id=? and area_id=? and is_delete=0", ruleId, ladderId, rehearsalId, areaId).
  71. Count(t)
  72. }