Files
quyun/backend/app/model/user_posts.funcs.gen.go
2025-05-26 12:25:55 +08:00

140 lines
4.0 KiB
Go

package model
import (
"context"
"time"
. "github.com/go-jet/jet/v2/postgres"
"github.com/samber/lo"
log "github.com/sirupsen/logrus"
)
// conds
func (m *UserPosts) CondID(id int64) Cond {
return func(cond BoolExpression) BoolExpression {
return cond.AND(tblUserPosts.ID.EQ(Int(id)))
}
}
// funcs
func (m *UserPosts) log() *log.Entry {
return log.WithField("model", "UserPosts")
}
func (m *UserPosts) Create(ctx context.Context) error {
m.CreatedAt = time.Now()
m.UpdatedAt = time.Now()
stmt := tblMedias.INSERT(tblUserPosts.MutableColumns).MODEL(m).RETURNING(tblMedias.AllColumns)
m.log().WithField("func", "Create").Info(stmt.DebugSql())
if err := stmt.QueryContext(ctx, db, m); err != nil {
m.log().WithField("func", "Create").Errorf("error creating UserPosts item: %v", err)
return err
}
m.log().WithField("func", "Create").Infof("UserPosts item created successfully")
return nil
}
func (m *UserPosts) BatchCreate(ctx context.Context, models []*UserPosts) error {
stmt := tblUserPosts.INSERT(tblUserPosts.MutableColumns).MODELS(models)
m.log().WithField("func", "BatchCreate").Info(stmt.DebugSql())
if _, err := stmt.ExecContext(ctx, db); err != nil {
m.log().WithField("func", "Create").Errorf("error creating UserPosts item: %v", err)
return err
}
m.log().WithField("func", "BatchCreate").Infof("UserPosts items created successfully")
return nil
}
func (m *UserPosts) Delete(ctx context.Context) error {
stmt := tblUserPosts.DELETE().WHERE(tblUserPosts.ID.EQ(Int(m.ID)))
m.log().WithField("func", "Delete").Info(stmt.DebugSql())
if err := stmt.QueryContext(ctx, db, m); err != nil {
m.log().WithField("func", "Delete").Errorf("error deleting UserPosts item: %v", err)
return err
}
m.log().WithField("func", "Delete").Infof("UserPosts item deleted successfully")
return nil
}
// BatchDelete
func (m *UserPosts) BatchDelete(ctx context.Context, ids []int64) error {
condIds := lo.Map(ids, func(id int64, _ int) Expression {
return Int64(id)
})
stmt := tblUserPosts.DELETE().WHERE(tblUserPosts.ID.IN(condIds...))
m.log().WithField("func", "BatchDelete").Info(stmt.DebugSql())
if err := stmt.QueryContext(ctx, db, m); err != nil {
m.log().WithField("func", "BatchDelete").Errorf("error deleting UserPosts items: %v", err)
return err
}
m.log().WithField("func", "BatchDelete").WithField("ids", ids).Infof("UserPosts items deleted successfully")
return nil
}
func (m *UserPosts) Update(ctx context.Context) error {
m.UpdatedAt = time.Now()
stmt := tblUserPosts.UPDATE(tblUserPostsUpdateMutableColumns).MODEL(m).WHERE(tblUserPosts.ID.EQ(Int(m.ID))).RETURNING(tblUserPosts.AllColumns)
m.log().WithField("func", "Update").Info(stmt.DebugSql())
if err := stmt.QueryContext(ctx, db, m); err != nil {
m.log().WithField("func", "Update").Errorf("error updating UserPosts item: %v", err)
return err
}
m.log().WithField("func", "Update").Infof("UserPosts item updated successfully")
return nil
}
// GetByCond
func (m *UserPosts) GetByCond(ctx context.Context, conds ...Cond) (*UserPosts, error) {
cond := CondTrue(conds...)
stmt := tblUserPosts.SELECT(tblUserPosts.AllColumns).WHERE(cond)
m.log().WithField("func", "GetByCond").Info(stmt.DebugSql())
if err := stmt.QueryContext(ctx, db, m); err != nil {
m.log().WithField("func", "GetByCond").Errorf("error getting UserPosts item by ID: %v", err)
return nil, err
}
m.log().WithField("func", "GetByCond").Infof("UserPosts item retrieved successfully")
return m, nil
}
// GetByID
func (m *UserPosts) GetByID(ctx context.Context, id int64, conds ...Cond) (*UserPosts, error) {
return m.GetByCond(ctx, CondJoin(m.CondID(id), conds...)...)
}
// Count
func (m *UserPosts) Count(ctx context.Context, conds ...Cond) (int64, error) {
cond := CondTrue(conds...)
tbl := tblUserPosts
stmt := tbl.SELECT(COUNT(tbl.ID).AS("count")).WHERE(cond)
m.log().Infof("sql: %s", stmt.DebugSql())
var count struct {
Count int64
}
if err := stmt.QueryContext(ctx, db, &count); err != nil {
m.log().Errorf("error counting UserPosts items: %v", err)
return 0, err
}
return count.Count, nil
}