expenses.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package dao
  2. import (
  3. "server/dao/system"
  4. "server/global"
  5. )
  6. type Expenses struct {
  7. global.GVA_MODEL
  8. Reimburser int `json:"reimburser" form:"reimburser" gorm:"comment:报销人"`
  9. SysUser system.SysUser `json:"user" form:"user" gorm:"foreignKey:Reimburser;references:id;"`
  10. DepartmentId int `json:"departmentId" form:"departmentId" gorm:"comment:部门id"`
  11. Department Department `json:"department" form:"department" gorm:"foreignKey:DepartmentId;references:id;"`
  12. ExpenditureAmount float64 `json:"expenditureAmount" form:"expenditureAmount" gorm:"comment:支出金额;type:double(10,2)"`
  13. DepositAmount float64 `json:"depositAmount" form:"depositAmount" gorm:"comment:支入金额;type:double(10,2)"`
  14. FeeTime string `json:"feeTime" form:"feeTime" gorm:"comment:时间"`
  15. Genre int `json:"genre" form:"genre" gorm:"comment:费用类型id"`
  16. ExpensesGenre ExpensesGenre `json:"expensesGenre" form:"expensesGenre" gorm:"foreignKey:Genre;references:id;"`
  17. ExpenseDetail string `json:"expenseDetail" form:"expenseDetail" gorm:"comment:费用明细;type:varchar(400)"`
  18. Remarks string `json:"remarks" form:"remarks" gorm:"comment:备注"`
  19. ThenBalance float64 `json:"thenBalance" form:"thenBalance" gorm:"comment:当时余额;type:double(10,2)"`
  20. }
  21. type ExpensesResult struct {
  22. Reimburser int `json:"reimburser" form:"reimburser" gorm:"comment:报销人"`
  23. SysUser system.SysUser `json:"user" form:"user" gorm:"foreignKey:Reimburser;references:id;"`
  24. ExpenditureAmountSum float64
  25. DepositAmountSum float64
  26. DepartmentId int `json:"departmentId" form:"departmentId" gorm:"comment:部门id"`
  27. Department Department `json:"department" form:"department" gorm:"foreignKey:DepartmentId;references:id;"`
  28. Expenses []Expenses `json:"expenses" form:"expenses" gorm:"-"`
  29. }
  30. func (Expenses) TableName() string {
  31. return "expenses"
  32. }
  33. func QueryExpensesList(limit, offset, genre, name int, dayTime, monthTime, yearTime string) (expenses []Expenses, total int64, err error) {
  34. // 创建db
  35. db := global.GVA_DB.Model(&Expenses{})
  36. // 如果有条件搜索 下方会自动创建搜索语句
  37. if genre != 0 {
  38. db = db.Where("genre = ?", genre)
  39. }
  40. if name != 0 {
  41. db = db.Where("reimburser = ?", name)
  42. }
  43. if dayTime != "" {
  44. db = db.Where("DATE_FORMAT(fee_time, '%Y-%m-%d') = ?", dayTime)
  45. }
  46. if monthTime != "" {
  47. db = db.Where("DATE_FORMAT(fee_time, '%Y-%m') = ?", monthTime)
  48. }
  49. if yearTime != "" {
  50. db = db.Where("DATE_FORMAT(fee_time, '%Y') = ?", yearTime)
  51. }
  52. err = db.Count(&total).Error
  53. if err != nil {
  54. return
  55. }
  56. err = db.Order("fee_time desc,created_at desc").Limit(limit).Offset(offset).Preload("SysUser").Preload("Department").Preload("ExpensesGenre").Find(&expenses).Error
  57. return expenses, total, err
  58. }
  59. // QueryExpensesSumByPeople 查询
  60. func QueryExpensesSumByPeople(limit, offset, genre, name int, dayTime, monthTime, yearTime string) (results []ExpensesResult, total int64, err error) {
  61. db := global.GVA_DB.Model(&Expenses{}).Select("reimburser,SUM(expenditure_amount) as expenditure_amount_sum,SUM(deposit_amount) as deposit_amount_sum,department_id")
  62. // 如果有条件搜索 下方会自动创建搜索语句
  63. if genre != 0 {
  64. db = db.Where("genre = ?", genre)
  65. }
  66. if name != 0 {
  67. db = db.Where("reimburser = ?", name)
  68. }
  69. if dayTime != "" {
  70. db = db.Where("DATE_FORMAT(fee_time, '%Y-%m-%d') = ?", dayTime)
  71. }
  72. if monthTime != "" {
  73. db = db.Where("DATE_FORMAT(fee_time, '%Y-%m') = ?", monthTime)
  74. }
  75. if yearTime != "" {
  76. db = db.Where("DATE_FORMAT(fee_time, '%Y') = ?", yearTime)
  77. }
  78. err = db.Group("reimburser,department_id").Count(&total).Error
  79. if err != nil {
  80. return
  81. }
  82. err = db.Limit(limit).Offset(offset).Preload("SysUser").Preload("Department").Scan(&results).Error
  83. return
  84. }
  85. func QuerySurplus() (interface{}, error) {
  86. type Result struct {
  87. FeeTime string
  88. ExpenditureAmountSum float64
  89. DepositAmountSum float64
  90. Surplus float64
  91. }
  92. var results []Result
  93. db := global.GVA_DB.Model(&Expenses{}).Select("DATE_FORMAT(fee_time, '%Y-%m') AS fee_time, SUM(expenditure_amount) AS expenditure_amount_sum,SUM(deposit_amount) AS deposit_amount_sum,(SUM(deposit_amount) - SUM(expenditure_amount)) AS surplus")
  94. err := db.Group("DATE_FORMAT(fee_time, '%Y-%m')").Scan(&results).Error
  95. return results, err
  96. }
  97. func QueryExpensesByGenre(genre int) (expenses []Expenses, err error) {
  98. err = global.GVA_DB.Model(&Expenses{}).Where("genre = ?", genre).Find(&expenses).Error
  99. return expenses, err
  100. }
  101. func QueryExpensesByProjectId(projectId int) (expenses []Expenses, err error) {
  102. err = global.GVA_DB.Model(&Expenses{}).Where("project_id = ?", projectId).Find(&expenses).Error
  103. return expenses, err
  104. }
  105. func QueryExpensesById(id int) (expenses Expenses, err error) {
  106. err = global.GVA_DB.Where("id =?", id).Preload("SysUser").Preload("Department").Preload("ExpensesGenre").First(&expenses).Error
  107. return expenses, err
  108. }
  109. func (e Expenses) CreateExpenses() error {
  110. return global.GVA_DB.Create(&e).Error
  111. }
  112. func (e Expenses) UpdateExpenses() error {
  113. return global.GVA_DB.Model(&Expenses{}).Select("*").Omit("created_at").Where("id = ?", e.ID).Updates(&e).Error
  114. }
  115. func (e Expenses) DeleteExpenses() error {
  116. return global.GVA_DB.Unscoped().Where("id = ?", e.ID).Delete(&e).Error
  117. }