98 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package repository
 | 
						||
 | 
						||
import (
 | 
						||
	"git.huangwc.com/pig/pig-farm-controller/internal/infra/models"
 | 
						||
	"gorm.io/gorm"
 | 
						||
)
 | 
						||
 | 
						||
// PigPenRepository 定义了与猪栏模型相关的数据库操作接口。
 | 
						||
type PigPenRepository interface {
 | 
						||
	CreatePen(pen *models.Pen) error
 | 
						||
	// GetPenByID 根据ID获取单个猪栏 (非事务性)
 | 
						||
	GetPenByID(id uint) (*models.Pen, error)
 | 
						||
	// GetPenByIDTx 根据ID获取单个猪栏 (事务性)
 | 
						||
	GetPenByIDTx(tx *gorm.DB, id uint) (*models.Pen, error)
 | 
						||
	ListPens() ([]models.Pen, error)
 | 
						||
	// UpdatePen 更新一个猪栏,返回受影响的行数和错误
 | 
						||
	UpdatePen(pen *models.Pen) (int64, error)
 | 
						||
	// DeletePen 根据ID删除一个猪栏,返回受影响的行数和错误
 | 
						||
	DeletePen(id uint) (int64, error)
 | 
						||
	// GetPensByBatchIDTx 根据批次ID获取所有关联的猪栏 (事务性)
 | 
						||
	GetPensByBatchIDTx(tx *gorm.DB, batchID uint) ([]*models.Pen, error)
 | 
						||
	// UpdatePenFieldsTx 更新猪栏的指定字段 (事务性)
 | 
						||
	UpdatePenFieldsTx(tx *gorm.DB, penID uint, updates map[string]interface{}) error
 | 
						||
}
 | 
						||
 | 
						||
// gormPigPenRepository 是 PigPenRepository 接口的 GORM 实现。
 | 
						||
type gormPigPenRepository struct {
 | 
						||
	db *gorm.DB
 | 
						||
}
 | 
						||
 | 
						||
// NewGormPigPenRepository 创建一个新的 PigPenRepository GORM 实现实例。
 | 
						||
func NewGormPigPenRepository(db *gorm.DB) PigPenRepository {
 | 
						||
	return &gormPigPenRepository{db: db}
 | 
						||
}
 | 
						||
 | 
						||
// CreatePen 创建一个新的猪栏
 | 
						||
func (r *gormPigPenRepository) CreatePen(pen *models.Pen) error {
 | 
						||
	return r.db.Create(pen).Error
 | 
						||
}
 | 
						||
 | 
						||
// GetPenByID 根据ID获取单个猪栏 (非事务性)
 | 
						||
func (r *gormPigPenRepository) GetPenByID(id uint) (*models.Pen, error) {
 | 
						||
	return r.GetPenByIDTx(r.db, id) // 非Tx方法直接调用Tx方法
 | 
						||
}
 | 
						||
 | 
						||
// GetPenByIDTx 在指定的事务中,通过ID获取单个猪栏信息。
 | 
						||
func (r *gormPigPenRepository) 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 列出所有猪栏
 | 
						||
func (r *gormPigPenRepository) ListPens() ([]models.Pen, error) {
 | 
						||
	var pens []models.Pen
 | 
						||
	if err := r.db.Find(&pens).Error; err != nil {
 | 
						||
		return nil, err
 | 
						||
	}
 | 
						||
	return pens, nil
 | 
						||
}
 | 
						||
 | 
						||
// UpdatePen 更新一个猪栏,返回受影响的行数和错误
 | 
						||
func (r *gormPigPenRepository) UpdatePen(pen *models.Pen) (int64, error) {
 | 
						||
	result := r.db.Model(&models.Pen{}).Where("id = ?", pen.ID).Updates(pen)
 | 
						||
	if result.Error != nil {
 | 
						||
		return 0, result.Error
 | 
						||
	}
 | 
						||
	return result.RowsAffected, nil
 | 
						||
}
 | 
						||
 | 
						||
// DeletePen 根据ID删除一个猪栏,返回受影响的行数和错误
 | 
						||
func (r *gormPigPenRepository) DeletePen(id uint) (int64, error) {
 | 
						||
	result := r.db.Delete(&models.Pen{}, id)
 | 
						||
	if result.Error != nil {
 | 
						||
		return 0, result.Error
 | 
						||
	}
 | 
						||
	return result.RowsAffected, nil
 | 
						||
}
 | 
						||
 | 
						||
// GetPensByBatchIDTx 在指定的事务中,获取一个猪群当前关联的所有猪栏。
 | 
						||
func (r *gormPigPenRepository) GetPensByBatchIDTx(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
 | 
						||
}
 | 
						||
 | 
						||
// UpdatePenFieldsTx 在指定的事务中,更新一个猪栏的指定字段。
 | 
						||
func (r *gormPigPenRepository) UpdatePenFieldsTx(tx *gorm.DB, penID uint, updates map[string]interface{}) error {
 | 
						||
	result := tx.Model(&models.Pen{}).Where("id = ?", penID).Updates(updates)
 | 
						||
	return result.Error
 | 
						||
}
 |