fix
liujiandao
2024-04-28 de4bcd1dead50b05f716bc5718be5540bdb96783
service/test/supplier.go
@@ -11,42 +11,42 @@
}
// CreateSupplier 创建Supplier记录
// Author [piexlmax](https://github.com/piexlmax)
func (sService *SupplierService) CreateSupplier(s *test.Supplier) (err error) {
   err = global.GVA_DB.Create(s).Error
   return err
}
// DeleteSupplier 删除Supplier记录
// Author [piexlmax](https://github.com/piexlmax)
func (sService *SupplierService) DeleteSupplier(s test.Supplier) (err error) {
   err = global.GVA_DB.Delete(&s).Error
   return err
}
// DeleteSupplierByIds 批量删除Supplier记录
// Author [piexlmax](https://github.com/piexlmax)
func (sService *SupplierService) DeleteSupplierByIds(ids request.IdsReq) (err error) {
   err = global.GVA_DB.Delete(&[]test.Supplier{}, "id in ?", ids.Ids).Error
   return err
}
// UpdateSupplier 更新Supplier记录
// Author [piexlmax](https://github.com/piexlmax)
func (sService *SupplierService) UpdateSupplier(s test.Supplier) (err error) {
   err = global.GVA_DB.Updates(&s).Error
   return err
}
// GetSupplier 根据id获取Supplier记录
// Author [piexlmax](https://github.com/piexlmax)
func (sService *SupplierService) GetSupplier(id uint) (s test.Supplier, err error) {
   err = global.GVA_DB.Where("id = ?", id).First(&s).Error
   err = global.GVA_DB.Model(&test.Supplier{}).Where("id = ?", id).First(&s).Error
   return
}
// GetSupplierByNumber 根据编码获取Supplier记录
func (sService *SupplierService) GetSupplierByNumber(number string) (s test.Supplier, err error) {
   err = global.GVA_DB.Model(&test.Supplier{}).Where("number = ?", number).Preload("Contract").First(&s).Error
   return
}
// GetSupplierInfoList 分页获取Supplier记录
// Author [piexlmax](https://github.com/piexlmax)
func (sService *SupplierService) GetSupplierInfoList(info testReq.SupplierSearch) (list []test.Supplier, total int64, err error) {
   limit := info.PageSize
   offset := info.PageSize * (info.Page - 1)
@@ -54,6 +54,10 @@
   db := global.GVA_DB.Model(&test.Supplier{})
   var ss []test.Supplier
   // 如果有条件搜索 下方会自动创建搜索语句
   if info.Keyword != "" {
      keyword := "%" + info.Keyword + "%"
      db = db.Where("name LIKE ? or number LIKE ?", keyword, keyword)
   }
   if info.StartCreatedAt != nil && info.EndCreatedAt != nil {
      db = db.Where("created_at BETWEEN ? AND ?", info.StartCreatedAt, info.EndCreatedAt)
   }
@@ -64,7 +68,7 @@
      db = db.Where("number LIKE ?", "%"+info.Number+"%")
   }
   if info.SupplierType != "" {
      db = db.Where("supplier_type LIKE ?", "%"+info.SupplierType+"%")
      db = db.Where("srm_supplier_type LIKE ?", "%"+info.SupplierType+"%")
   }
   if info.Industry != "" {
      db = db.Where("industry LIKE ?", "%"+info.Industry+"%")
@@ -78,12 +82,15 @@
   if info.CreatedAt != nil {
      db = db.Where("created_at = ?", info.CreatedAt)
   }
   if info.Status != 0 {
      db = db.Where("status = ?", info.Status)
   }
   err = db.Count(&total).Error
   if err != nil {
      return
   }
   err = db.Debug().Limit(limit).Offset(offset).Preload("Contract").Find(&ss).Error
   err = db.Debug().Limit(limit).Offset(offset).Order("created_at desc").Preload("Contract").Find(&ss).Error
   return ss, total, err
}
@@ -92,3 +99,30 @@
   err = global.GVA_DB.Model(&test.Supplier{}).Where("id = ?", id).Update("status", status).Error
   return err
}
func (sService *SupplierService) MaxAutoIncr() (int, error) {
   var total int64
   err := global.GVA_DB.Model(&test.Supplier{}).Count(&total).Error
   return int(total), err
}
func (sService *SupplierService) GetSupplierProduct(info testReq.SupplierProduct) ([]test.SupplierMaterial, int64, error) {
   limit := info.PageSize
   offset := info.PageSize * (info.Page - 1)
   // 创建db
   db := global.GVA_DB.Model(&test.SupplierMaterial{})
   var ps []test.SupplierMaterial
   var total int64
   if info.SupplierId > 0 {
      db = db.Where("supplier_id = ?", info.SupplierId)
   }
   if info.Number != "" {
      db = db.Where("number = ?", info.Number)
   }
   err := db.Count(&total).Error
   if err != nil {
      return ps, total, err
   }
   err = db.Limit(limit).Offset(offset).Order("id desc").Preload("Supplier").Find(&ps).Error
   return ps, total, err
}