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