1 Star 0 Fork 1.1K

高煜涛/福墩

forked from pixel/gin-vue-admin 
加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
level_three.go 3.33 KB
一键复制 编辑 原始数据 按行查看 历史
高煜涛 提交于 2024-11-25 11:46 +08:00 . 24/11/25
package hierarchy
import (
"errors"
"gitee.com/g-qs/fudun/server/global"
"gitee.com/g-qs/fudun/server/model/common/request"
"gitee.com/g-qs/fudun/server/model/hierarchy"
hierarchyReq "gitee.com/g-qs/fudun/server/model/hierarchy/request"
"gorm.io/gorm"
)
type LevelThreeService struct {
}
// CreateLevelThree 创建LevelThree记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelThreeService *LevelThreeService) CreateLevelThree(levelThree *hierarchy.LevelThree) (err error) {
err = global.GVA_DB.Create(levelThree).Error
return err
}
// DeleteLevelThree 删除LevelThree记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelThreeService *LevelThreeService) DeleteLevelThree(levelThree hierarchy.LevelThree) (err error) {
if !errors.Is(global.GVA_DB.Where("level_three_id = ?", levelThree.ID).First(&hierarchy.FdArticleVideo{}).Error, gorm.ErrRecordNotFound) {
return errors.New("此目录有视频类型文章存在禁止删除")
}
if !errors.Is(global.GVA_DB.Where("level_three_id = ?", levelThree.ID).First(&hierarchy.FdArticleAudio{}).Error, gorm.ErrRecordNotFound) {
return errors.New("此目录有音频类型文章存在禁止删除")
}
if !errors.Is(global.GVA_DB.Where("level_three_id = ?", levelThree.ID).First(&hierarchy.FdArticleGraphic{}).Error, gorm.ErrRecordNotFound) {
return errors.New("此目录有图文类型文章存在禁止删除")
}
if err = global.GVA_DB.Delete(&levelThree).Error; err != nil {
return errors.New("删除失败")
}
return
}
// DeleteLevelThreeByIds 批量删除LevelThree记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelThreeService *LevelThreeService) DeleteLevelThreeByIds(ids request.IdsReq) (err error) {
err = global.GVA_DB.Delete(&[]hierarchy.LevelThree{}, "id in ?", ids.Ids).Error
return err
}
// UpdateLevelThree 更新LevelThree记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelThreeService *LevelThreeService) UpdateLevelThree(levelThree hierarchy.LevelThree) (err error) {
err = global.GVA_DB.Save(&levelThree).Error
return err
}
// GetLevelThree 根据id获取LevelThree记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelThreeService *LevelThreeService) GetLevelThree(id uint) (levelThree hierarchy.LevelThree, err error) {
err = global.GVA_DB.Where("id = ?", id).First(&levelThree).Error
return
}
// GetLevelThreeInfoList 分页获取LevelThree记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelThreeService *LevelThreeService) GetLevelThreeInfoList(info hierarchyReq.LevelThreeSearch) (list []hierarchy.LevelThree, total int64, err error) {
limit := info.PageSize
offset := info.PageSize * (info.Page - 1)
// 创建db
db := global.GVA_DB.Model(&hierarchy.LevelThree{})
var levelThrees []hierarchy.LevelThree
if info.LevelTwoID != 0 {
db = db.Where("level_two_id = ?", info.LevelTwoID)
}
// 如果有条件搜索 下方会自动创建搜索语句
if info.StartCreatedAt != nil && info.EndCreatedAt != nil {
db = db.Where("created_at BETWEEN ? AND ?", info.StartCreatedAt, info.EndCreatedAt)
}
if info.Key != "" {
db = db.Where("key = ?", info.Key)
}
if info.Value != "" {
db = db.Where("value = ?", info.Value)
}
err = db.Count(&total).Error
if err != nil {
return
}
if limit != 0 {
db = db.Limit(limit).Offset(offset)
}
err = db.Find(&levelThrees).Error
return levelThrees, total, err
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/g-qs/fudun.git
git@gitee.com:g-qs/fudun.git
g-qs
fudun
福墩
36c3b20778a1

搜索帮助