2025-10-03 18:27:53 +08:00
|
|
|
|
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)
|
|
|
|
|
|
UpdatePigHouse(house *models.PigHouse) error
|
|
|
|
|
|
DeletePigHouse(id uint) error
|
2025-10-03 22:33:43 +08:00
|
|
|
|
CountPensInHouse(houseID uint) (int64, error)
|
2025-10-03 18:27:53 +08:00
|
|
|
|
|
|
|
|
|
|
// Pen methods
|
|
|
|
|
|
CreatePen(pen *models.Pen) error
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPenByID 根据ID获取单个猪栏 (非事务性)
|
2025-10-03 18:27:53 +08:00
|
|
|
|
GetPenByID(id uint) (*models.Pen, error)
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPenByIDTx 根据ID获取单个猪栏 (事务性)
|
|
|
|
|
|
GetPenByIDTx(tx *gorm.DB, id uint) (*models.Pen, error)
|
2025-10-03 18:27:53 +08:00
|
|
|
|
ListPens() ([]models.Pen, error)
|
|
|
|
|
|
UpdatePen(pen *models.Pen) error
|
|
|
|
|
|
DeletePen(id uint) error
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPensByBatchID 根据批次ID获取所有关联的猪栏 (事务性)
|
|
|
|
|
|
GetPensByBatchID(tx *gorm.DB, batchID uint) ([]models.Pen, error)
|
|
|
|
|
|
// UpdatePenFields 更新猪栏的指定字段 (事务性)
|
|
|
|
|
|
UpdatePenFields(tx *gorm.DB, penID uint, updates map[string]interface{}) error
|
2025-10-03 22:33:43 +08:00
|
|
|
|
|
|
|
|
|
|
// PigBatch methods
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPigBatchByID 根据ID获取单个猪批次 (非事务性)
|
2025-10-03 22:33:43 +08:00
|
|
|
|
GetPigBatchByID(id uint) (*models.PigBatch, error)
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPigBatchByIDTx 根据ID获取单个猪批次 (事务性)
|
|
|
|
|
|
GetPigBatchByIDTx(tx *gorm.DB, id uint) (*models.PigBatch, error)
|
2025-10-03 18:27:53 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 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 创建一个新的猪舍
|
2025-10-03 18:27:53 +08:00
|
|
|
|
func (r *gormPigFarmRepository) CreatePigHouse(house *models.PigHouse) error {
|
|
|
|
|
|
return r.db.Create(house).Error
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPigHouseByID 根据ID获取单个猪舍
|
2025-10-03 18:27:53 +08:00
|
|
|
|
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 列出所有猪舍
|
2025-10-03 18:27:53 +08:00
|
|
|
|
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:47:27 +08:00
|
|
|
|
// UpdatePigHouse 更新一个猪舍
|
2025-10-03 18:27:53 +08:00
|
|
|
|
func (r *gormPigFarmRepository) UpdatePigHouse(house *models.PigHouse) error {
|
|
|
|
|
|
result := r.db.Model(&models.PigHouse{}).Where("id = ?", house.ID).Updates(house)
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
|
|
return result.Error
|
|
|
|
|
|
}
|
|
|
|
|
|
if result.RowsAffected == 0 {
|
2025-10-04 00:47:27 +08:00
|
|
|
|
return gorm.ErrRecordNotFound // 未找到要更新的猪舍或数据未改变
|
2025-10-03 18:27:53 +08:00
|
|
|
|
}
|
|
|
|
|
|
return nil
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// DeletePigHouse 根据ID删除一个猪舍
|
2025-10-03 18:27:53 +08:00
|
|
|
|
func (r *gormPigFarmRepository) DeletePigHouse(id uint) error {
|
2025-10-03 22:33:43 +08:00
|
|
|
|
result := r.db.Delete(&models.PigHouse{}, id)
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
|
|
return result.Error
|
|
|
|
|
|
}
|
|
|
|
|
|
if result.RowsAffected == 0 {
|
2025-10-04 00:47:27 +08:00
|
|
|
|
return gorm.ErrRecordNotFound // 未找到要删除的猪舍
|
2025-10-03 22:33:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
return nil
|
|
|
|
|
|
}
|
|
|
|
|
|
|
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
|
2025-10-03 18:27:53 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// --- Pen Implementation ---
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// CreatePen 创建一个新的猪栏
|
2025-10-03 18:27:53 +08:00
|
|
|
|
func (r *gormPigFarmRepository) CreatePen(pen *models.Pen) error {
|
2025-10-03 22:33:43 +08:00
|
|
|
|
return r.db.Create(pen).Error
|
2025-10-03 18:27:53 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPenByID 根据ID获取单个猪栏 (非事务性)
|
2025-10-03 18:27:53 +08:00
|
|
|
|
func (r *gormPigFarmRepository) GetPenByID(id uint) (*models.Pen, error) {
|
|
|
|
|
|
var pen models.Pen
|
|
|
|
|
|
if err := r.db.First(&pen, id).Error; err != nil {
|
|
|
|
|
|
return nil, err
|
|
|
|
|
|
}
|
|
|
|
|
|
return &pen, nil
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPenByIDTx 根据ID获取单个猪栏 (事务性)
|
|
|
|
|
|
func (r *gormPigFarmRepository) GetPenByIDTx(tx *gorm.DB, id uint) (*models.Pen, error) {
|
|
|
|
|
|
var pen models.Pen
|
|
|
|
|
|
if err := tx.First(&pen, id).Error; err != nil {
|
|
|
|
|
|
return nil, err
|
|
|
|
|
|
}
|
|
|
|
|
|
return &pen, nil
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ListPens 列出所有猪栏
|
2025-10-03 18:27:53 +08:00
|
|
|
|
func (r *gormPigFarmRepository) ListPens() ([]models.Pen, error) {
|
|
|
|
|
|
var pens []models.Pen
|
|
|
|
|
|
if err := r.db.Find(&pens).Error; err != nil {
|
|
|
|
|
|
return nil, err
|
|
|
|
|
|
}
|
|
|
|
|
|
return pens, nil
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// UpdatePen 更新一个猪栏
|
2025-10-03 18:27:53 +08:00
|
|
|
|
func (r *gormPigFarmRepository) UpdatePen(pen *models.Pen) error {
|
2025-10-03 22:33:43 +08:00
|
|
|
|
result := r.db.Model(&models.Pen{}).Where("id = ?", pen.ID).Updates(pen)
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
|
|
return result.Error
|
|
|
|
|
|
}
|
|
|
|
|
|
if result.RowsAffected == 0 {
|
2025-10-04 00:47:27 +08:00
|
|
|
|
return gorm.ErrRecordNotFound // 未找到要更新的猪栏或数据未改变
|
2025-10-03 22:33:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
return nil
|
2025-10-03 18:27:53 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// DeletePen 根据ID删除一个猪栏
|
2025-10-03 18:27:53 +08:00
|
|
|
|
func (r *gormPigFarmRepository) DeletePen(id uint) error {
|
2025-10-03 22:33:43 +08:00
|
|
|
|
result := r.db.Delete(&models.Pen{}, id)
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
|
|
return result.Error
|
|
|
|
|
|
}
|
|
|
|
|
|
if result.RowsAffected == 0 {
|
2025-10-04 00:47:27 +08:00
|
|
|
|
return gorm.ErrRecordNotFound // 未找到要删除的猪栏
|
2025-10-03 22:33:43 +08:00
|
|
|
|
}
|
|
|
|
|
|
return nil
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPensByBatchID 根据批次ID获取所有关联的猪栏 (事务性)
|
|
|
|
|
|
func (r *gormPigFarmRepository) GetPensByBatchID(tx *gorm.DB, batchID uint) ([]models.Pen, error) {
|
|
|
|
|
|
var pens []models.Pen
|
|
|
|
|
|
// 注意:PigBatchID 是指针类型,需要处理 nil 值
|
|
|
|
|
|
result := tx.Where("pig_batch_id = ?", batchID).Find(&pens)
|
|
|
|
|
|
if result.Error != nil {
|
|
|
|
|
|
return nil, result.Error
|
|
|
|
|
|
}
|
|
|
|
|
|
return pens, nil
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// UpdatePenFields 更新猪栏的指定字段 (事务性)
|
|
|
|
|
|
func (r *gormPigFarmRepository) UpdatePenFields(tx *gorm.DB, penID uint, updates map[string]interface{}) error {
|
|
|
|
|
|
result := tx.Model(&models.Pen{}).Where("id = ?", penID).Updates(updates)
|
|
|
|
|
|
return result.Error
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-10-03 22:33:43 +08:00
|
|
|
|
// --- PigBatch Implementation ---
|
|
|
|
|
|
|
2025-10-04 00:47:27 +08:00
|
|
|
|
// GetPigBatchByID 根据ID获取单个猪批次 (非事务性)
|
2025-10-03 22:33:43 +08:00
|
|
|
|
func (r *gormPigFarmRepository) GetPigBatchByID(id uint) (*models.PigBatch, error) {
|
|
|
|
|
|
var batch models.PigBatch
|
|
|
|
|
|
if err := r.db.First(&batch, id).Error; err != nil {
|
|
|
|
|
|
return nil, err
|
|
|
|
|
|
}
|
|
|
|
|
|
return &batch, nil
|
2025-10-03 18:27:53 +08:00
|
|
|
|
}
|
2025-10-04 00:47:27 +08:00
|
|
|
|
|
|
|
|
|
|
// GetPigBatchByIDTx 根据ID获取单个猪批次 (事务性)
|
|
|
|
|
|
func (r *gormPigFarmRepository) GetPigBatchByIDTx(tx *gorm.DB, id uint) (*models.PigBatch, error) {
|
|
|
|
|
|
var batch models.PigBatch
|
|
|
|
|
|
if err := tx.First(&batch, id).Error; err != nil {
|
|
|
|
|
|
return nil, err
|
|
|
|
|
|
}
|
|
|
|
|
|
return &batch, nil
|
|
|
|
|
|
}
|