linstrom/storage-new/dbgen/notes.gen.go
mstar 68859642f3
Some checks are pending
/ test (push) Waiting to run
chore(new-storage): Auto-generate new storage impl
2025-03-27 15:57:00 +01:00

903 lines
24 KiB
Go

// Code generated by gorm.io/gen. DO NOT EDIT.
// Code generated by gorm.io/gen. DO NOT EDIT.
// Code generated by gorm.io/gen. DO NOT EDIT.
package dbgen
import (
"context"
"git.mstar.dev/mstar/linstrom/storage-new/models"
"gorm.io/gorm"
"gorm.io/gorm/clause"
"gorm.io/gorm/schema"
"gorm.io/gen"
"gorm.io/gen/field"
"gorm.io/plugin/dbresolver"
)
func newNote(db *gorm.DB, opts ...gen.DOOption) note {
_note := note{}
_note.noteDo.UseDB(db, opts...)
_note.noteDo.UseModel(&models.Note{})
tableName := _note.noteDo.TableName()
_note.ALL = field.NewAsterisk(tableName)
_note.ID = field.NewString(tableName, "id")
_note.CreatedAt = field.NewTime(tableName, "created_at")
_note.UpdatedAt = field.NewTime(tableName, "updated_at")
_note.DeletedAt = field.NewField(tableName, "deleted_at")
_note.CreatorId = field.NewString(tableName, "creator_id")
_note.Remote = field.NewBool(tableName, "remote")
_note.RawContent = field.NewString(tableName, "raw_content")
_note.ContentWarning = field.NewString(tableName, "content_warning")
_note.RepliesTo = field.NewString(tableName, "replies_to")
_note.Quotes = field.NewString(tableName, "quotes")
_note.AccessLevel = field.NewField(tableName, "access_level")
_note.OriginServer = field.NewString(tableName, "origin_server")
_note.AttachmentRelations = noteHasManyAttachmentRelations{
db: db.Session(&gorm.Session{}),
RelationField: field.NewRelation("AttachmentRelations", "models.NoteToAttachment"),
Note: struct {
field.RelationField
AttachmentRelations struct {
field.RelationField
}
EmoteRelations struct {
field.RelationField
Note struct {
field.RelationField
}
Emote struct {
field.RelationField
Metadata struct {
field.RelationField
}
Server struct {
field.RelationField
}
}
}
PingRelations struct {
field.RelationField
Note struct {
field.RelationField
}
PingTarget struct {
field.RelationField
}
}
Tags struct {
field.RelationField
Note struct {
field.RelationField
}
}
}{
RelationField: field.NewRelation("AttachmentRelations.Note", "models.Note"),
AttachmentRelations: struct {
field.RelationField
}{
RelationField: field.NewRelation("AttachmentRelations.Note.AttachmentRelations", "models.NoteToAttachment"),
},
EmoteRelations: struct {
field.RelationField
Note struct {
field.RelationField
}
Emote struct {
field.RelationField
Metadata struct {
field.RelationField
}
Server struct {
field.RelationField
}
}
}{
RelationField: field.NewRelation("AttachmentRelations.Note.EmoteRelations", "models.NoteToEmote"),
Note: struct {
field.RelationField
}{
RelationField: field.NewRelation("AttachmentRelations.Note.EmoteRelations.Note", "models.Note"),
},
Emote: struct {
field.RelationField
Metadata struct {
field.RelationField
}
Server struct {
field.RelationField
}
}{
RelationField: field.NewRelation("AttachmentRelations.Note.EmoteRelations.Emote", "models.Emote"),
Metadata: struct {
field.RelationField
}{
RelationField: field.NewRelation("AttachmentRelations.Note.EmoteRelations.Emote.Metadata", "models.MediaMetadata"),
},
Server: struct {
field.RelationField
}{
RelationField: field.NewRelation("AttachmentRelations.Note.EmoteRelations.Emote.Server", "models.RemoteServer"),
},
},
},
PingRelations: struct {
field.RelationField
Note struct {
field.RelationField
}
PingTarget struct {
field.RelationField
}
}{
RelationField: field.NewRelation("AttachmentRelations.Note.PingRelations", "models.NoteToPing"),
Note: struct {
field.RelationField
}{
RelationField: field.NewRelation("AttachmentRelations.Note.PingRelations.Note", "models.Note"),
},
PingTarget: struct {
field.RelationField
}{
RelationField: field.NewRelation("AttachmentRelations.Note.PingRelations.PingTarget", "models.User"),
},
},
Tags: struct {
field.RelationField
Note struct {
field.RelationField
}
}{
RelationField: field.NewRelation("AttachmentRelations.Note.Tags", "models.NoteTag"),
Note: struct {
field.RelationField
}{
RelationField: field.NewRelation("AttachmentRelations.Note.Tags.Note", "models.Note"),
},
},
},
Attachment: struct {
field.RelationField
}{
RelationField: field.NewRelation("AttachmentRelations.Attachment", "models.MediaMetadata"),
},
}
_note.EmoteRelations = noteHasManyEmoteRelations{
db: db.Session(&gorm.Session{}),
RelationField: field.NewRelation("EmoteRelations", "models.NoteToEmote"),
}
_note.PingRelations = noteHasManyPingRelations{
db: db.Session(&gorm.Session{}),
RelationField: field.NewRelation("PingRelations", "models.NoteToPing"),
}
_note.Tags = noteHasManyTags{
db: db.Session(&gorm.Session{}),
RelationField: field.NewRelation("Tags", "models.NoteTag"),
}
_note.fillFieldMap()
return _note
}
type note struct {
noteDo
ALL field.Asterisk
ID field.String
CreatedAt field.Time
UpdatedAt field.Time
DeletedAt field.Field
CreatorId field.String
Remote field.Bool
RawContent field.String
ContentWarning field.String
RepliesTo field.String
Quotes field.String
AccessLevel field.Field
OriginServer field.String
AttachmentRelations noteHasManyAttachmentRelations
EmoteRelations noteHasManyEmoteRelations
PingRelations noteHasManyPingRelations
Tags noteHasManyTags
fieldMap map[string]field.Expr
}
func (n note) Table(newTableName string) *note {
n.noteDo.UseTable(newTableName)
return n.updateTableName(newTableName)
}
func (n note) As(alias string) *note {
n.noteDo.DO = *(n.noteDo.As(alias).(*gen.DO))
return n.updateTableName(alias)
}
func (n *note) updateTableName(table string) *note {
n.ALL = field.NewAsterisk(table)
n.ID = field.NewString(table, "id")
n.CreatedAt = field.NewTime(table, "created_at")
n.UpdatedAt = field.NewTime(table, "updated_at")
n.DeletedAt = field.NewField(table, "deleted_at")
n.CreatorId = field.NewString(table, "creator_id")
n.Remote = field.NewBool(table, "remote")
n.RawContent = field.NewString(table, "raw_content")
n.ContentWarning = field.NewString(table, "content_warning")
n.RepliesTo = field.NewString(table, "replies_to")
n.Quotes = field.NewString(table, "quotes")
n.AccessLevel = field.NewField(table, "access_level")
n.OriginServer = field.NewString(table, "origin_server")
n.fillFieldMap()
return n
}
func (n *note) GetFieldByName(fieldName string) (field.OrderExpr, bool) {
_f, ok := n.fieldMap[fieldName]
if !ok || _f == nil {
return nil, false
}
_oe, ok := _f.(field.OrderExpr)
return _oe, ok
}
func (n *note) fillFieldMap() {
n.fieldMap = make(map[string]field.Expr, 16)
n.fieldMap["id"] = n.ID
n.fieldMap["created_at"] = n.CreatedAt
n.fieldMap["updated_at"] = n.UpdatedAt
n.fieldMap["deleted_at"] = n.DeletedAt
n.fieldMap["creator_id"] = n.CreatorId
n.fieldMap["remote"] = n.Remote
n.fieldMap["raw_content"] = n.RawContent
n.fieldMap["content_warning"] = n.ContentWarning
n.fieldMap["replies_to"] = n.RepliesTo
n.fieldMap["quotes"] = n.Quotes
n.fieldMap["access_level"] = n.AccessLevel
n.fieldMap["origin_server"] = n.OriginServer
}
func (n note) clone(db *gorm.DB) note {
n.noteDo.ReplaceConnPool(db.Statement.ConnPool)
return n
}
func (n note) replaceDB(db *gorm.DB) note {
n.noteDo.ReplaceDB(db)
return n
}
type noteHasManyAttachmentRelations struct {
db *gorm.DB
field.RelationField
Note struct {
field.RelationField
AttachmentRelations struct {
field.RelationField
}
EmoteRelations struct {
field.RelationField
Note struct {
field.RelationField
}
Emote struct {
field.RelationField
Metadata struct {
field.RelationField
}
Server struct {
field.RelationField
}
}
}
PingRelations struct {
field.RelationField
Note struct {
field.RelationField
}
PingTarget struct {
field.RelationField
}
}
Tags struct {
field.RelationField
Note struct {
field.RelationField
}
}
}
Attachment struct {
field.RelationField
}
}
func (a noteHasManyAttachmentRelations) Where(conds ...field.Expr) *noteHasManyAttachmentRelations {
if len(conds) == 0 {
return &a
}
exprs := make([]clause.Expression, 0, len(conds))
for _, cond := range conds {
exprs = append(exprs, cond.BeCond().(clause.Expression))
}
a.db = a.db.Clauses(clause.Where{Exprs: exprs})
return &a
}
func (a noteHasManyAttachmentRelations) WithContext(ctx context.Context) *noteHasManyAttachmentRelations {
a.db = a.db.WithContext(ctx)
return &a
}
func (a noteHasManyAttachmentRelations) Session(session *gorm.Session) *noteHasManyAttachmentRelations {
a.db = a.db.Session(session)
return &a
}
func (a noteHasManyAttachmentRelations) Model(m *models.Note) *noteHasManyAttachmentRelationsTx {
return &noteHasManyAttachmentRelationsTx{a.db.Model(m).Association(a.Name())}
}
type noteHasManyAttachmentRelationsTx struct{ tx *gorm.Association }
func (a noteHasManyAttachmentRelationsTx) Find() (result []*models.NoteToAttachment, err error) {
return result, a.tx.Find(&result)
}
func (a noteHasManyAttachmentRelationsTx) Append(values ...*models.NoteToAttachment) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Append(targetValues...)
}
func (a noteHasManyAttachmentRelationsTx) Replace(values ...*models.NoteToAttachment) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Replace(targetValues...)
}
func (a noteHasManyAttachmentRelationsTx) Delete(values ...*models.NoteToAttachment) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Delete(targetValues...)
}
func (a noteHasManyAttachmentRelationsTx) Clear() error {
return a.tx.Clear()
}
func (a noteHasManyAttachmentRelationsTx) Count() int64 {
return a.tx.Count()
}
type noteHasManyEmoteRelations struct {
db *gorm.DB
field.RelationField
}
func (a noteHasManyEmoteRelations) Where(conds ...field.Expr) *noteHasManyEmoteRelations {
if len(conds) == 0 {
return &a
}
exprs := make([]clause.Expression, 0, len(conds))
for _, cond := range conds {
exprs = append(exprs, cond.BeCond().(clause.Expression))
}
a.db = a.db.Clauses(clause.Where{Exprs: exprs})
return &a
}
func (a noteHasManyEmoteRelations) WithContext(ctx context.Context) *noteHasManyEmoteRelations {
a.db = a.db.WithContext(ctx)
return &a
}
func (a noteHasManyEmoteRelations) Session(session *gorm.Session) *noteHasManyEmoteRelations {
a.db = a.db.Session(session)
return &a
}
func (a noteHasManyEmoteRelations) Model(m *models.Note) *noteHasManyEmoteRelationsTx {
return &noteHasManyEmoteRelationsTx{a.db.Model(m).Association(a.Name())}
}
type noteHasManyEmoteRelationsTx struct{ tx *gorm.Association }
func (a noteHasManyEmoteRelationsTx) Find() (result []*models.NoteToEmote, err error) {
return result, a.tx.Find(&result)
}
func (a noteHasManyEmoteRelationsTx) Append(values ...*models.NoteToEmote) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Append(targetValues...)
}
func (a noteHasManyEmoteRelationsTx) Replace(values ...*models.NoteToEmote) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Replace(targetValues...)
}
func (a noteHasManyEmoteRelationsTx) Delete(values ...*models.NoteToEmote) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Delete(targetValues...)
}
func (a noteHasManyEmoteRelationsTx) Clear() error {
return a.tx.Clear()
}
func (a noteHasManyEmoteRelationsTx) Count() int64 {
return a.tx.Count()
}
type noteHasManyPingRelations struct {
db *gorm.DB
field.RelationField
}
func (a noteHasManyPingRelations) Where(conds ...field.Expr) *noteHasManyPingRelations {
if len(conds) == 0 {
return &a
}
exprs := make([]clause.Expression, 0, len(conds))
for _, cond := range conds {
exprs = append(exprs, cond.BeCond().(clause.Expression))
}
a.db = a.db.Clauses(clause.Where{Exprs: exprs})
return &a
}
func (a noteHasManyPingRelations) WithContext(ctx context.Context) *noteHasManyPingRelations {
a.db = a.db.WithContext(ctx)
return &a
}
func (a noteHasManyPingRelations) Session(session *gorm.Session) *noteHasManyPingRelations {
a.db = a.db.Session(session)
return &a
}
func (a noteHasManyPingRelations) Model(m *models.Note) *noteHasManyPingRelationsTx {
return &noteHasManyPingRelationsTx{a.db.Model(m).Association(a.Name())}
}
type noteHasManyPingRelationsTx struct{ tx *gorm.Association }
func (a noteHasManyPingRelationsTx) Find() (result []*models.NoteToPing, err error) {
return result, a.tx.Find(&result)
}
func (a noteHasManyPingRelationsTx) Append(values ...*models.NoteToPing) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Append(targetValues...)
}
func (a noteHasManyPingRelationsTx) Replace(values ...*models.NoteToPing) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Replace(targetValues...)
}
func (a noteHasManyPingRelationsTx) Delete(values ...*models.NoteToPing) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Delete(targetValues...)
}
func (a noteHasManyPingRelationsTx) Clear() error {
return a.tx.Clear()
}
func (a noteHasManyPingRelationsTx) Count() int64 {
return a.tx.Count()
}
type noteHasManyTags struct {
db *gorm.DB
field.RelationField
}
func (a noteHasManyTags) Where(conds ...field.Expr) *noteHasManyTags {
if len(conds) == 0 {
return &a
}
exprs := make([]clause.Expression, 0, len(conds))
for _, cond := range conds {
exprs = append(exprs, cond.BeCond().(clause.Expression))
}
a.db = a.db.Clauses(clause.Where{Exprs: exprs})
return &a
}
func (a noteHasManyTags) WithContext(ctx context.Context) *noteHasManyTags {
a.db = a.db.WithContext(ctx)
return &a
}
func (a noteHasManyTags) Session(session *gorm.Session) *noteHasManyTags {
a.db = a.db.Session(session)
return &a
}
func (a noteHasManyTags) Model(m *models.Note) *noteHasManyTagsTx {
return &noteHasManyTagsTx{a.db.Model(m).Association(a.Name())}
}
type noteHasManyTagsTx struct{ tx *gorm.Association }
func (a noteHasManyTagsTx) Find() (result []*models.NoteTag, err error) {
return result, a.tx.Find(&result)
}
func (a noteHasManyTagsTx) Append(values ...*models.NoteTag) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Append(targetValues...)
}
func (a noteHasManyTagsTx) Replace(values ...*models.NoteTag) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Replace(targetValues...)
}
func (a noteHasManyTagsTx) Delete(values ...*models.NoteTag) (err error) {
targetValues := make([]interface{}, len(values))
for i, v := range values {
targetValues[i] = v
}
return a.tx.Delete(targetValues...)
}
func (a noteHasManyTagsTx) Clear() error {
return a.tx.Clear()
}
func (a noteHasManyTagsTx) Count() int64 {
return a.tx.Count()
}
type noteDo struct{ gen.DO }
type INoteDo interface {
gen.SubQuery
Debug() INoteDo
WithContext(ctx context.Context) INoteDo
WithResult(fc func(tx gen.Dao)) gen.ResultInfo
ReplaceDB(db *gorm.DB)
ReadDB() INoteDo
WriteDB() INoteDo
As(alias string) gen.Dao
Session(config *gorm.Session) INoteDo
Columns(cols ...field.Expr) gen.Columns
Clauses(conds ...clause.Expression) INoteDo
Not(conds ...gen.Condition) INoteDo
Or(conds ...gen.Condition) INoteDo
Select(conds ...field.Expr) INoteDo
Where(conds ...gen.Condition) INoteDo
Order(conds ...field.Expr) INoteDo
Distinct(cols ...field.Expr) INoteDo
Omit(cols ...field.Expr) INoteDo
Join(table schema.Tabler, on ...field.Expr) INoteDo
LeftJoin(table schema.Tabler, on ...field.Expr) INoteDo
RightJoin(table schema.Tabler, on ...field.Expr) INoteDo
Group(cols ...field.Expr) INoteDo
Having(conds ...gen.Condition) INoteDo
Limit(limit int) INoteDo
Offset(offset int) INoteDo
Count() (count int64, err error)
Scopes(funcs ...func(gen.Dao) gen.Dao) INoteDo
Unscoped() INoteDo
Create(values ...*models.Note) error
CreateInBatches(values []*models.Note, batchSize int) error
Save(values ...*models.Note) error
First() (*models.Note, error)
Take() (*models.Note, error)
Last() (*models.Note, error)
Find() ([]*models.Note, error)
FindInBatch(batchSize int, fc func(tx gen.Dao, batch int) error) (results []*models.Note, err error)
FindInBatches(result *[]*models.Note, batchSize int, fc func(tx gen.Dao, batch int) error) error
Pluck(column field.Expr, dest interface{}) error
Delete(...*models.Note) (info gen.ResultInfo, err error)
Update(column field.Expr, value interface{}) (info gen.ResultInfo, err error)
UpdateSimple(columns ...field.AssignExpr) (info gen.ResultInfo, err error)
Updates(value interface{}) (info gen.ResultInfo, err error)
UpdateColumn(column field.Expr, value interface{}) (info gen.ResultInfo, err error)
UpdateColumnSimple(columns ...field.AssignExpr) (info gen.ResultInfo, err error)
UpdateColumns(value interface{}) (info gen.ResultInfo, err error)
UpdateFrom(q gen.SubQuery) gen.Dao
Attrs(attrs ...field.AssignExpr) INoteDo
Assign(attrs ...field.AssignExpr) INoteDo
Joins(fields ...field.RelationField) INoteDo
Preload(fields ...field.RelationField) INoteDo
FirstOrInit() (*models.Note, error)
FirstOrCreate() (*models.Note, error)
FindByPage(offset int, limit int) (result []*models.Note, count int64, err error)
ScanByPage(result interface{}, offset int, limit int) (count int64, err error)
Scan(result interface{}) (err error)
Returning(value interface{}, columns ...string) INoteDo
UnderlyingDB() *gorm.DB
schema.Tabler
}
func (n noteDo) Debug() INoteDo {
return n.withDO(n.DO.Debug())
}
func (n noteDo) WithContext(ctx context.Context) INoteDo {
return n.withDO(n.DO.WithContext(ctx))
}
func (n noteDo) ReadDB() INoteDo {
return n.Clauses(dbresolver.Read)
}
func (n noteDo) WriteDB() INoteDo {
return n.Clauses(dbresolver.Write)
}
func (n noteDo) Session(config *gorm.Session) INoteDo {
return n.withDO(n.DO.Session(config))
}
func (n noteDo) Clauses(conds ...clause.Expression) INoteDo {
return n.withDO(n.DO.Clauses(conds...))
}
func (n noteDo) Returning(value interface{}, columns ...string) INoteDo {
return n.withDO(n.DO.Returning(value, columns...))
}
func (n noteDo) Not(conds ...gen.Condition) INoteDo {
return n.withDO(n.DO.Not(conds...))
}
func (n noteDo) Or(conds ...gen.Condition) INoteDo {
return n.withDO(n.DO.Or(conds...))
}
func (n noteDo) Select(conds ...field.Expr) INoteDo {
return n.withDO(n.DO.Select(conds...))
}
func (n noteDo) Where(conds ...gen.Condition) INoteDo {
return n.withDO(n.DO.Where(conds...))
}
func (n noteDo) Order(conds ...field.Expr) INoteDo {
return n.withDO(n.DO.Order(conds...))
}
func (n noteDo) Distinct(cols ...field.Expr) INoteDo {
return n.withDO(n.DO.Distinct(cols...))
}
func (n noteDo) Omit(cols ...field.Expr) INoteDo {
return n.withDO(n.DO.Omit(cols...))
}
func (n noteDo) Join(table schema.Tabler, on ...field.Expr) INoteDo {
return n.withDO(n.DO.Join(table, on...))
}
func (n noteDo) LeftJoin(table schema.Tabler, on ...field.Expr) INoteDo {
return n.withDO(n.DO.LeftJoin(table, on...))
}
func (n noteDo) RightJoin(table schema.Tabler, on ...field.Expr) INoteDo {
return n.withDO(n.DO.RightJoin(table, on...))
}
func (n noteDo) Group(cols ...field.Expr) INoteDo {
return n.withDO(n.DO.Group(cols...))
}
func (n noteDo) Having(conds ...gen.Condition) INoteDo {
return n.withDO(n.DO.Having(conds...))
}
func (n noteDo) Limit(limit int) INoteDo {
return n.withDO(n.DO.Limit(limit))
}
func (n noteDo) Offset(offset int) INoteDo {
return n.withDO(n.DO.Offset(offset))
}
func (n noteDo) Scopes(funcs ...func(gen.Dao) gen.Dao) INoteDo {
return n.withDO(n.DO.Scopes(funcs...))
}
func (n noteDo) Unscoped() INoteDo {
return n.withDO(n.DO.Unscoped())
}
func (n noteDo) Create(values ...*models.Note) error {
if len(values) == 0 {
return nil
}
return n.DO.Create(values)
}
func (n noteDo) CreateInBatches(values []*models.Note, batchSize int) error {
return n.DO.CreateInBatches(values, batchSize)
}
// Save : !!! underlying implementation is different with GORM
// The method is equivalent to executing the statement: db.Clauses(clause.OnConflict{UpdateAll: true}).Create(values)
func (n noteDo) Save(values ...*models.Note) error {
if len(values) == 0 {
return nil
}
return n.DO.Save(values)
}
func (n noteDo) First() (*models.Note, error) {
if result, err := n.DO.First(); err != nil {
return nil, err
} else {
return result.(*models.Note), nil
}
}
func (n noteDo) Take() (*models.Note, error) {
if result, err := n.DO.Take(); err != nil {
return nil, err
} else {
return result.(*models.Note), nil
}
}
func (n noteDo) Last() (*models.Note, error) {
if result, err := n.DO.Last(); err != nil {
return nil, err
} else {
return result.(*models.Note), nil
}
}
func (n noteDo) Find() ([]*models.Note, error) {
result, err := n.DO.Find()
return result.([]*models.Note), err
}
func (n noteDo) FindInBatch(batchSize int, fc func(tx gen.Dao, batch int) error) (results []*models.Note, err error) {
buf := make([]*models.Note, 0, batchSize)
err = n.DO.FindInBatches(&buf, batchSize, func(tx gen.Dao, batch int) error {
defer func() { results = append(results, buf...) }()
return fc(tx, batch)
})
return results, err
}
func (n noteDo) FindInBatches(result *[]*models.Note, batchSize int, fc func(tx gen.Dao, batch int) error) error {
return n.DO.FindInBatches(result, batchSize, fc)
}
func (n noteDo) Attrs(attrs ...field.AssignExpr) INoteDo {
return n.withDO(n.DO.Attrs(attrs...))
}
func (n noteDo) Assign(attrs ...field.AssignExpr) INoteDo {
return n.withDO(n.DO.Assign(attrs...))
}
func (n noteDo) Joins(fields ...field.RelationField) INoteDo {
for _, _f := range fields {
n = *n.withDO(n.DO.Joins(_f))
}
return &n
}
func (n noteDo) Preload(fields ...field.RelationField) INoteDo {
for _, _f := range fields {
n = *n.withDO(n.DO.Preload(_f))
}
return &n
}
func (n noteDo) FirstOrInit() (*models.Note, error) {
if result, err := n.DO.FirstOrInit(); err != nil {
return nil, err
} else {
return result.(*models.Note), nil
}
}
func (n noteDo) FirstOrCreate() (*models.Note, error) {
if result, err := n.DO.FirstOrCreate(); err != nil {
return nil, err
} else {
return result.(*models.Note), nil
}
}
func (n noteDo) FindByPage(offset int, limit int) (result []*models.Note, count int64, err error) {
result, err = n.Offset(offset).Limit(limit).Find()
if err != nil {
return
}
if size := len(result); 0 < limit && 0 < size && size < limit {
count = int64(size + offset)
return
}
count, err = n.Offset(-1).Limit(-1).Count()
return
}
func (n noteDo) ScanByPage(result interface{}, offset int, limit int) (count int64, err error) {
count, err = n.Count()
if err != nil {
return
}
err = n.Offset(offset).Limit(limit).Scan(result)
return
}
func (n noteDo) Scan(result interface{}) (err error) {
return n.DO.Scan(result)
}
func (n noteDo) Delete(models ...*models.Note) (result gen.ResultInfo, err error) {
return n.DO.Delete(models)
}
func (n *noteDo) withDO(do gen.Dao) *noteDo {
n.DO = *do.(*gen.DO)
return n
}