Files
pig-farm-controller/internal/infra/repository/pig_farm_repository.go

80 lines
2.5 KiB
Go
Raw Normal View History

package repository
import (
"git.huangwc.com/pig/pig-farm-controller/internal/infra/models"
"gorm.io/gorm"
)
// PigFarmRepository 定义了与猪场资产(猪舍、猪栏)相关的数据库操作接口
type PigFarmRepository interface {
// PigHouse methods
CreatePigHouse(house *models.PigHouse) error
GetPigHouseByID(id uint) (*models.PigHouse, error)
ListPigHouses() ([]models.PigHouse, error)
2025-10-04 00:58:29 +08:00
// UpdatePigHouse 更新一个猪舍,返回受影响的行数和错误
UpdatePigHouse(house *models.PigHouse) (int64, error)
// DeletePigHouse 根据ID删除一个猪舍返回受影响的行数和错误
DeletePigHouse(id uint) (int64, error)
2025-10-03 22:33:43 +08:00
CountPensInHouse(houseID uint) (int64, error)
}
// gormPigFarmRepository 是 PigFarmRepository 的 GORM 实现
type gormPigFarmRepository struct {
db *gorm.DB
}
// NewGormPigFarmRepository 创建一个新的 PigFarmRepository GORM 实现实例
func NewGormPigFarmRepository(db *gorm.DB) PigFarmRepository {
return &gormPigFarmRepository{db: db}
}
// --- PigHouse Implementation ---
2025-10-04 00:47:27 +08:00
// CreatePigHouse 创建一个新的猪舍
func (r *gormPigFarmRepository) CreatePigHouse(house *models.PigHouse) error {
return r.db.Create(house).Error
}
2025-10-04 00:47:27 +08:00
// GetPigHouseByID 根据ID获取单个猪舍
func (r *gormPigFarmRepository) GetPigHouseByID(id uint) (*models.PigHouse, error) {
var house models.PigHouse
if err := r.db.First(&house, id).Error; err != nil {
return nil, err
}
return &house, nil
}
2025-10-04 00:47:27 +08:00
// ListPigHouses 列出所有猪舍
func (r *gormPigFarmRepository) ListPigHouses() ([]models.PigHouse, error) {
var houses []models.PigHouse
if err := r.db.Find(&houses).Error; err != nil {
return nil, err
}
return houses, nil
}
2025-10-04 00:58:29 +08:00
// UpdatePigHouse 更新一个猪舍,返回受影响的行数和错误
func (r *gormPigFarmRepository) UpdatePigHouse(house *models.PigHouse) (int64, error) {
result := r.db.Model(&models.PigHouse{}).Where("id = ?", house.ID).Updates(house)
if result.Error != nil {
2025-10-04 00:58:29 +08:00
return 0, result.Error
}
2025-10-04 00:58:29 +08:00
return result.RowsAffected, nil
}
2025-10-04 00:58:29 +08:00
// DeletePigHouse 根据ID删除一个猪舍返回受影响的行数和错误
func (r *gormPigFarmRepository) DeletePigHouse(id uint) (int64, error) {
2025-10-03 22:33:43 +08:00
result := r.db.Delete(&models.PigHouse{}, id)
if result.Error != nil {
2025-10-04 00:58:29 +08:00
return 0, result.Error
2025-10-03 22:33:43 +08:00
}
2025-10-04 00:58:29 +08:00
return result.RowsAffected, nil
2025-10-03 22:33:43 +08:00
}
2025-10-04 00:47:27 +08:00
// CountPensInHouse 统计猪舍中的猪栏数量
2025-10-03 22:33:43 +08:00
func (r *gormPigFarmRepository) CountPensInHouse(houseID uint) (int64, error) {
var count int64
err := r.db.Model(&models.Pen{}).Where("house_id = ?", houseID).Count(&count).Error
return count, err
}