互动
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.

76 lines
3.7 KiB

5 years ago
5 years ago
4 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
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. package models
  2. import (
  3. "time"
  4. "git.ouxuan.net/tommy/osmanthuswine/src/core"
  5. )
  6. const BullyScreenHistoryTableName = TableNamePrefix + "bully_screen_history"
  7. //霸屏历史表
  8. type BullyScreenHistory struct {
  9. Id int `json:"id" xorm:"not null pk autoincr INT(11)"`
  10. IsDelete bool `json:"is_delete" xorm:"not null default(0) comment('删除') TINYINT(1)"`
  11. CreatedAt time.Time `json:"created_at" xorm:"not null created comment('创建时间') DATETIME"`
  12. UpdatedAt time.Time `json:"updated_at" xorm:"not null updated comment('更新时间') DATETIME"`
  13. BullyScreenServerId int `json:"bully_screen_server_id" xorm:"not null default 0 comment('霸屏服务得id') INT(11)"`
  14. OutTradeNo string `json:"out_trade_no" xorm:"not null default '' comment('微信订单号') VARCHAR(128)"`
  15. CustomerId int `json:"customer_id" xorm:"not null default 0 comment('客户id') INT(11)"`
  16. ArchId int `json:"arch_id" xorm:"not null default 0 comment('归档id') INT(11)"`
  17. ActivityId int `json:"activity_id" xorm:"not null default 0 comment('互动id') INT(11)"`
  18. UserId int `json:"user_id" xorm:"not null default 0 comment('用户得id') INT(11)"`
  19. Nickname string `json:"nickname" xorm:"not null default '' comment('发送者昵称') VARCHAR(128)"`
  20. RehearsalId int `json:"rehearsal_id" xorm:"not null default 0 comment('彩排id/ 0是正式') INT(11)"`
  21. Style int `json:"style" xorm:"not null default 0 comment('服务样式') INT(11)"`
  22. Second int `json:"second" xorm:"not null default 0 comment('霸屏时间(秒)') INT(11)"`
  23. Content string `json:"content" xorm:"not null comment('内容') TEXT"`
  24. Status int `json:"status" xorm:"not null default(0) comment('[-1未支付,0未审核,1未通过,2已通过,3已推送,4已作废]') INT(11)"`
  25. Amount float64 `json:"amount" xorm:"not null default 0.00 comment('霸屏金额') DECIMAL(18)"`
  26. ReviewTime int `json:"review_time" xorm:"not null default 0 comment('审核的时间') INT(11)"`
  27. Version int `json:"version" xorm:"not null version comment('乐观锁') INT(11)"`
  28. }
  29. func (t *BullyScreenHistory) TableName() string {
  30. return BullyScreenHistoryTableName
  31. }
  32. func (t *BullyScreenHistory) GetByOutTradeNo(outTradeNo string) (bool, error) {
  33. return core.GetXormAuto().Where("is_delete=0 and out_trade_no=?", outTradeNo).Get(t)
  34. }
  35. func (t *BullyScreenHistory) UpdateStatus(id int, status int) (int64, error) {
  36. t.Status = status
  37. return core.GetXormAuto().ID(id).Cols("status").Update(t)
  38. }
  39. // 更改未支付状态
  40. func (t *BullyScreenHistory) UpdateStatusByOutTradeNo(outTradeNo string, status int) (int64, error) {
  41. t.Status = status
  42. return core.GetXormAuto().Where("is_delete=0 and status=-1 and out_trade_no=?", outTradeNo).
  43. Cols("status").Update(t)
  44. }
  45. func (t *BullyScreenHistory) UpdateStatusByIds(ids []int, status int) error {
  46. if len(ids) > 0 {
  47. t.Status = status
  48. _, err := core.GetXormAuto().In("id", ids).Cols("status").
  49. Update(&BullyScreenHistory{Status: status})
  50. return err
  51. }
  52. return nil
  53. }
  54. func GetBullyScreenHistoryByIds(ids interface{}) ([]*BullyScreenHistory, error) {
  55. result := make([]*BullyScreenHistory, 0)
  56. err := core.GetXormAuto().Where("is_delete=0 and status=0").In("id", ids).Find(&result)
  57. return result, err
  58. }
  59. func (t *BullyScreenHistory) SumSecond(serverId, rehearsalId, archId interface{}) (float64, error) {
  60. totalSecond, err := core.GetXormAuto().Where("bully_screen_server_id=? and status=3 and "+
  61. " is_delete=false and rehearsal_id=? and arch_id=?", serverId, rehearsalId, archId).
  62. Sum(new(BullyScreenHistory), "second")
  63. return totalSecond, err
  64. }