|
@@ -0,0 +1,118 @@
|
|
|
+package dao
|
|
|
+
|
|
|
+import "server/global"
|
|
|
+
|
|
|
+type Expenses struct {
|
|
|
+ global.GVA_MODEL
|
|
|
+ Reimburser int `json:"reimburser" form:"reimburser" gorm:"comment:报销人"`
|
|
|
+ SysUser SysUser `json:"user" form:"user" gorm:"foreignKey:Reimburser;references:id;"`
|
|
|
+ DepartmentId int `json:"departmentId" form:"departmentId" gorm:"comment:部门id"`
|
|
|
+ Department Department `json:"department" form:"department" gorm:"foreignKey:DepartmentId;references:id;"`
|
|
|
+ ExpenditureAmount float64 `json:"expenditureAmount" form:"expenditureAmount" gorm:"comment:支出金额;type:double(10,2)"`
|
|
|
+ DepositAmount float64 `json:"depositAmount" form:"depositAmount" gorm:"comment:支入金额;type:double(10,2)"`
|
|
|
+ FeeTime string `json:"feeTime" form:"feeTime" gorm:"comment:时间"`
|
|
|
+ Genre int `json:"genre" form:"genre" gorm:"comment:费用类型id"`
|
|
|
+ ExpensesGenre ExpensesGenre `json:"expensesGenre" form:"expensesGenre" gorm:"foreignKey:Genre;references:id;"`
|
|
|
+ ProjectId int `json:"projectId" form:"projectId" gorm:"comment:项目id"`
|
|
|
+ Project Project `json:"project" form:"project" gorm:"foreignKey:ProjectId;references:id"`
|
|
|
+ ExpenseDetail string `json:"expenseDetail" form:"expenseDetail" gorm:"comment:费用明细"`
|
|
|
+ Remarks string `json:"remarks" form:"remarks" gorm:"comment:备注"`
|
|
|
+ ThenBalance float64 `json:"thenBalance" form:"thenBalance" gorm:"comment:当时余额;type:double(10,2)"`
|
|
|
+}
|
|
|
+
|
|
|
+type ExpensesResult struct {
|
|
|
+ Reimburser int `json:"reimburser" form:"reimburser" gorm:"comment:报销人"`
|
|
|
+ SysUser SysUser `json:"user" form:"user" gorm:"foreignKey:Reimburser;references:id;"`
|
|
|
+ ExpenditureAmountSum float64
|
|
|
+ DepositAmountSum float64
|
|
|
+ DepartmentId int `json:"departmentId" form:"departmentId" gorm:"comment:部门id"`
|
|
|
+ Department Department `json:"department" form:"department" gorm:"foreignKey:DepartmentId;references:id;"`
|
|
|
+ Expenses []Expenses `json:"expenses" form:"expenses" gorm:"-"`
|
|
|
+}
|
|
|
+
|
|
|
+func (Expenses) TableName() string {
|
|
|
+ return "expenses"
|
|
|
+}
|
|
|
+
|
|
|
+func QueryExpensesList(limit, offset, genre, projectId, name int, dayTime, monthTime, yearTime string) (expenses []Expenses, total int64, err error) {
|
|
|
+ // 创建db
|
|
|
+ db := global.GVA_DB.Model(&Expenses{})
|
|
|
+ // 如果有条件搜索 下方会自动创建搜索语句
|
|
|
+ if genre != 0 {
|
|
|
+ db = db.Where("genre = ?", genre)
|
|
|
+ }
|
|
|
+ if projectId != 0 {
|
|
|
+ db = db.Where("project_id = ?", projectId)
|
|
|
+ }
|
|
|
+ if name != 0 {
|
|
|
+ db = db.Where("reimburser = ?", name)
|
|
|
+ }
|
|
|
+ if dayTime != "" {
|
|
|
+ db = db.Where("DATE_FORMAT(fee_time, '%Y-%m-%d') = ?", dayTime)
|
|
|
+ }
|
|
|
+ if monthTime != "" {
|
|
|
+ db = db.Where("DATE_FORMAT(fee_time, '%Y-%m') = ?", monthTime)
|
|
|
+ }
|
|
|
+ if yearTime != "" {
|
|
|
+ db = db.Where("DATE_FORMAT(fee_time, '%Y') = ?", yearTime)
|
|
|
+ }
|
|
|
+ err = db.Count(&total).Error
|
|
|
+ if err != nil {
|
|
|
+ return
|
|
|
+ }
|
|
|
+ err = db.Order("id desc").Limit(limit).Offset(offset).Preload("SysUser").Preload("Department").Preload("ExpensesGenre").Preload("Project").Find(&expenses).Error
|
|
|
+ return expenses, total, err
|
|
|
+}
|
|
|
+
|
|
|
+func QueryExpensesSumByPeople(limit, offset, genre, projectId, name int, dayTime, monthTime, yearTime string) (results []ExpensesResult, total int64, err error) {
|
|
|
+ db := global.GVA_DB.Model(&Expenses{}).Select("reimburser,SUM(expenditure_amount) as expenditure_amount_sum,SUM(deposit_amount) as deposit_amount_sum,department_id")
|
|
|
+ // 如果有条件搜索 下方会自动创建搜索语句
|
|
|
+ if genre != 0 {
|
|
|
+ db = db.Where("genre = ?", genre)
|
|
|
+ }
|
|
|
+ if projectId != 0 {
|
|
|
+ db = db.Where("project_id = ?", projectId)
|
|
|
+ }
|
|
|
+ if name != 0 {
|
|
|
+ db = db.Where("reimburser = ?", name)
|
|
|
+ }
|
|
|
+ if dayTime != "" {
|
|
|
+ db = db.Where("DATE_FORMAT(fee_time, '%Y-%m-%d') = ?", dayTime)
|
|
|
+ }
|
|
|
+ if monthTime != "" {
|
|
|
+ db = db.Where("DATE_FORMAT(fee_time, '%Y-%m') = ?", monthTime)
|
|
|
+ }
|
|
|
+ if yearTime != "" {
|
|
|
+ db = db.Where("DATE_FORMAT(fee_time, '%Y') = ?", yearTime)
|
|
|
+ }
|
|
|
+ err = db.Group("reimburser,department_id").Limit(limit).Offset(offset).Preload("SysUser").Preload("Department").Count(&total).Scan(&results).Error
|
|
|
+
|
|
|
+ return
|
|
|
+}
|
|
|
+
|
|
|
+func QuerySurplus() (interface{}, error) {
|
|
|
+ type Result struct {
|
|
|
+ FeeTime string
|
|
|
+ ExpenditureAmountSum float64
|
|
|
+ DepositAmountSum float64
|
|
|
+ Surplus float64
|
|
|
+ }
|
|
|
+
|
|
|
+ var results []Result
|
|
|
+ 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")
|
|
|
+
|
|
|
+ err := db.Group("DATE_FORMAT(fee_time, '%Y-%m')").Scan(&results).Error
|
|
|
+ return results, err
|
|
|
+}
|
|
|
+
|
|
|
+func (e Expenses) CreateExpenses() error {
|
|
|
+ return global.GVA_DB.Create(&e).Error
|
|
|
+}
|
|
|
+
|
|
|
+func (e Expenses) UpdateExpenses() error {
|
|
|
+ return global.GVA_DB.Model(&Expenses{}).Updates(&e).Error
|
|
|
+}
|
|
|
+
|
|
|
+func (e Expenses) DeleteExpenses() error {
|
|
|
+ return global.GVA_DB.Unscoped().Where("id = ?", e.ID).Delete(&e).Error
|
|
|
+}
|