Files
xuanzhi-service/server/service/book/book_author_relation.go

71 lines
2.3 KiB
Go

package book
import (
"github.com/flipped-aurora/gin-vue-admin/server/global"
"github.com/flipped-aurora/gin-vue-admin/server/model/book"
bookReq "github.com/flipped-aurora/gin-vue-admin/server/model/book/request"
bookRes "github.com/flipped-aurora/gin-vue-admin/server/model/book/response"
commonReq "github.com/flipped-aurora/gin-vue-admin/server/model/common/request"
"gorm.io/gorm"
)
type BookAuthorRelationService struct{}
const bookAuthorRelationDisplaySelect = "bar.*, b.title AS book_title, ba.name AS author_name"
func (s *BookAuthorRelationService) CreateBookAuthorRelation(item book.BookAuthorRelation) error {
item = applyBookAuthorRelationDefaults(item)
if err := validateBookAuthorRelation(item); err != nil {
return err
}
return global.GVA_DB.Create(&item).Error
}
func (s *BookAuthorRelationService) DeleteBookAuthorRelation(item book.BookAuthorRelation) error {
return global.GVA_DB.Delete(&item).Error
}
func (s *BookAuthorRelationService) DeleteBookAuthorRelationByIds(ids commonReq.IdsReq) error {
return deleteByIDs[book.BookAuthorRelation](ids.Ids)
}
func (s *BookAuthorRelationService) UpdateBookAuthorRelation(item book.BookAuthorRelation) error {
if err := validateBookAuthorRelation(item); err != nil {
return err
}
return global.GVA_DB.Save(&item).Error
}
func (s *BookAuthorRelationService) GetBookAuthorRelation(id uint) (item bookRes.BookAuthorRelationDisplay, err error) {
err = bookAuthorRelationDisplayDB().
Select(bookAuthorRelationDisplaySelect).
Where("bar.id = ?", id).
Take(&item).Error
return
}
func (s *BookAuthorRelationService) GetBookAuthorRelationInfoList(info bookReq.BookAuthorRelationSearch) (list []bookRes.BookAuthorRelationListItem, total int64, err error) {
db := bookAuthorRelationDisplayDB()
if info.BookID != nil {
db = db.Where("bar.book_id = ?", *info.BookID)
}
if info.AuthorID != nil {
db = db.Where("bar.author_id = ?", *info.AuthorID)
}
err = db.Count(&total).Error
if err != nil {
return
}
err = db.Select(bookAuthorRelationDisplaySelect).
Scopes(paginate(info.PageInfo)).
Order("bar.book_id asc, bar.author_sort asc, bar.id desc").
Scan(&list).Error
return
}
func bookAuthorRelationDisplayDB() *gorm.DB {
return global.GVA_DB.Table("book_author_relation AS bar").
Joins("LEFT JOIN book AS b ON b.id = bar.book_id").
Joins("LEFT JOIN book_author AS ba ON ba.id = bar.author_id")
}