Skip to content

CRUD

Read / Select

分页

go
func (s *AppRepository) GetAppList(ctx context.Context, page int, size int) ([]AppDTO, int64, error) {
	var apps []model.App
	var total int64

	db := s.db.WithContext(ctx).Model(&model.App{})

	if err := db.Count(&total).Error; err != nil {
		return nil, 0, err
	}

	if err := db.Offset((page - 1) * size).
		Limit(size).
		Find(&apps).Error; err != nil {
		return nil, 0, err
	}

	return ToAppList(apps), total, nil
}

Exists

go
func (s *UserRepository) ExistsByEmail(ctx context.Context, email string) (bool, error) {

	var count int64
	err := s.db.WithContext(ctx).Model(&model.User{}).Where("email = ?", email).Count(&count).Error

	if err != nil {
		return false, err
	}
	// fmt.Println("count > ", count)

	if count > 0 {
		return true, nil
	}

	return false, nil
}

未成功

First/Take/Last:未命中会返回 ErrRecordNotFound

Find:未命中通常不报错,只是结果为空(切片长度 0)

go
func (s *UserRepository) ExistsByEmail(ctx context.Context, email string) (bool, error) {
	// 如果查不到,err 就一定会是 gorm.ErrRecordNotFound
	_, err := gorm.G[model.User](s.db).Where("email = ?", email).First(ctx)

	if err != nil && !errors.Is(err, gorm.ErrRecordNotFound) {
		return false, err
	}

	return true, nil
}

Create

todo

Update

todo

Delete

GORM 默认就是软删

go
func DeleteApp(ctx context.Context, id uint) error {
	return db.GetInstance().WithContext(ctx).Where("id = ?", id).Delete(&model.App{}).Error
}

硬删:

go
// 软删与硬删的区别仅仅只是 Unscoped()
func DeleteApp(ctx context.Context, id uint) error {
	return db.GetInstance().WithContext(ctx).Unscoped().Where("id = ?", id).Delete(&model.App{}).Error
}