1 Star 0 Fork 1.1K

高煜涛/福墩

forked from pixel/gin-vue-admin 
加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
level_one.go 4.03 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 LevelOneService struct {
}
// CreateLevelOne 创建LevelOne记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelOneService *LevelOneService) CreateLevelOne(levelOne *hierarchy.LevelOne) (err error) {
err = global.GVA_DB.Create(levelOne).Error
return err
}
// DeleteLevelOne 删除LevelOne记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelOneService *LevelOneService) DeleteLevelOne(levelOne hierarchy.LevelOne) (err error) {
if !errors.Is(global.GVA_DB.Where("level_one_id = ?", levelOne.ID).First(&hierarchy.FdArticleVideo{}).Error, gorm.ErrRecordNotFound) {
return errors.New("此目录有视频类型文章存在禁止删除")
}
if !errors.Is(global.GVA_DB.Where("level_one_id = ?", levelOne.ID).First(&hierarchy.FdArticleAudio{}).Error, gorm.ErrRecordNotFound) {
return errors.New("此目录有音频类型文章存在禁止删除")
}
if !errors.Is(global.GVA_DB.Where("level_one_id = ?", levelOne.ID).First(&hierarchy.FdArticleGraphic{}).Error, gorm.ErrRecordNotFound) {
return errors.New("此目录有图文类型文章存在禁止删除")
}
if err = global.GVA_DB.Delete(&levelOne).Error; err != nil {
return errors.New("删除失败")
}
return
}
// DeleteLevelOneByIds 批量删除LevelOne记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelOneService *LevelOneService) DeleteLevelOneByIds(ids request.IdsReq) (err error) {
err = global.GVA_DB.Delete(&[]hierarchy.LevelOne{}, "id in ?", ids.Ids).Error
return err
}
// UpdateLevelOne 更新LevelOne记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelOneService *LevelOneService) UpdateLevelOne(levelOne hierarchy.LevelOne) (err error) {
err = global.GVA_DB.Save(&levelOne).Error
return err
}
// GetLevelOne 根据id获取LevelOne记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelOneService *LevelOneService) GetLevelOne(id uint) (levelOne hierarchy.LevelOne, err error) {
err = global.GVA_DB.Where("id = ?", id).First(&levelOne).Error
return
}
// GetLevelOneInfoList 分页获取LevelOne记录
// Author [piexlmax](https://github.com/piexlmax)
func (levelOneService *LevelOneService) GetLevelOneInfoList(info hierarchyReq.LevelOneSearch) (list []hierarchy.LevelOne, total int64, err error) {
limit := info.PageSize
offset := info.PageSize * (info.Page - 1)
// 创建db
db := global.GVA_DB.Model(&hierarchy.LevelOne{})
var levelOnes []hierarchy.LevelOne
// 如果有条件搜索 下方会自动创建搜索语句
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(&levelOnes).Error
return levelOnes, total, err
}
// GetLearnLevelOneInfoList 分页获取学习一级目录
// Author [g-qs](https://gitee.com/g-qs)
func (levelOneService *LevelOneService) GetLearnLevelOneInfoList(info hierarchyReq.LevelOneSearch) (list []hierarchy.LevelOne, total int64, err error) {
limit := info.PageSize
offset := info.PageSize * (info.Page - 1)
// 创建db
db := global.GVA_DB.Model(&hierarchy.LevelOne{}).Where("`key` IN (?)", "jmgy")
var levelOnes []hierarchy.LevelOne
// 如果有条件搜索 下方会自动创建搜索语句
if info.StartCreatedAt != nil && info.EndCreatedAt != nil {
db = db.Where("created_at BETWEEN ? AND ?", info.StartCreatedAt, info.EndCreatedAt)
}
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(&levelOnes).Error
return levelOnes, total, err
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/g-qs/fudun.git
git@gitee.com:g-qs/fudun.git
g-qs
fudun
福墩
36c3b20778a1

搜索帮助