projectFee.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. package dao
  2. import "server/global"
  3. type ProjectFee struct {
  4. global.GVA_MODEL
  5. Reimburser int `json:"reimburser" form:"reimburser" gorm:"comment:报销人"`
  6. SysUser SysUser `json:"user" form:"user" gorm:"foreignKey:Reimburser;references:id;"`
  7. DepartmentId int `json:"departmentId" form:"departmentId" gorm:"comment:部门id"`
  8. Department Department `json:"department" form:"department" gorm:"foreignKey:DepartmentId;references:id;"`
  9. ExpenditureAmount float64 `json:"expenditureAmount" form:"expenditureAmount" gorm:"comment:支出金额;type:double(10,2)"`
  10. DepositAmount float64 `json:"depositAmount" form:"depositAmount" gorm:"comment:支入金额;type:double(10,2)"`
  11. FeeTime string `json:"feeTime" form:"feeTime" gorm:"comment:时间"`
  12. Genre int `json:"genre" form:"genre" gorm:"comment:费用类型id"`
  13. ProjectFeeGenre ProjectFeeGenre `json:"projectFeeGenre" form:"projectFeeGenre" gorm:"foreignKey:Genre;references:id;"`
  14. ProjectCode string `json:"projectCode" form:"projectCode" gorm:"comment:项目编号"`
  15. Project Project `json:"project" form:"project" gorm:"foreignKey:ProjectCode;references:code;"`
  16. ExpenseDetail string `json:"expenseDetail" form:"expenseDetail" gorm:"comment:费用明细;type:varchar(400)"`
  17. Remarks string `json:"remarks" form:"remarks" gorm:"comment:备注"`
  18. ThenBalance float64 `json:"thenBalance" form:"thenBalance" gorm:"comment:当时余额;type:double(10,2)"`
  19. }
  20. func (ProjectFee) TableName() string {
  21. return "project_fee"
  22. }
  23. func QueryProjectFeeList(limit, offset, genre, name int, code, dayTime, monthTime, yearTime string) (projectFee []ProjectFee, total int64, err error) {
  24. // 创建db
  25. db := global.GVA_DB.Model(&ProjectFee{})
  26. // 如果有条件搜索 下方会自动创建搜索语句
  27. if genre != 0 {
  28. db = db.Where("genre = ?", genre)
  29. }
  30. if name != 0 {
  31. db = db.Where("reimburser = ?", name)
  32. }
  33. if code != "" {
  34. db = db.Where("project_code = ?", code)
  35. }
  36. if dayTime != "" {
  37. db = db.Where("DATE_FORMAT(fee_time, '%Y-%m-%d') = ?", dayTime)
  38. }
  39. if monthTime != "" {
  40. db = db.Where("DATE_FORMAT(fee_time, '%Y-%m') = ?", monthTime)
  41. }
  42. if yearTime != "" {
  43. db = db.Where("DATE_FORMAT(fee_time, '%Y') = ?", yearTime)
  44. }
  45. err = db.Count(&total).Error
  46. if err != nil {
  47. return
  48. }
  49. err = db.Order("id desc").Limit(limit).Offset(offset).Preload("SysUser").Preload("Department").Preload("Project").Preload("ProjectFeeGenre").Find(&projectFee).Error
  50. return projectFee, total, err
  51. }
  52. func QueryProjectFeeByGenre(genre int) (projectFee []ProjectFee, err error) {
  53. err = global.GVA_DB.Model(&ProjectFee{}).Where("genre = ?", genre).Find(&projectFee).Error
  54. return projectFee, err
  55. }
  56. func (e ProjectFee) CreateProjectFee() error {
  57. return global.GVA_DB.Create(&e).Error
  58. }
  59. func (e ProjectFee) UpdateProjectFee() error {
  60. return global.GVA_DB.Model(&ProjectFee{}).Where("id = ?", e.ID).Updates(&e).Error
  61. }
  62. func (e ProjectFee) DeleteProjectFee() error {
  63. return global.GVA_DB.Unscoped().Where("id = ?", e.ID).Delete(&e).Error
  64. }