// 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 Creator struct { field.RelationField Icon struct { field.RelationField } Background struct { field.RelationField } Banner struct { field.RelationField } RemoteInfo struct { field.RelationField User struct { field.RelationField } } InfoFields struct { field.RelationField User struct { field.RelationField } } BeingTypes struct { field.RelationField User struct { field.RelationField } } Tags struct { field.RelationField User struct { field.RelationField } } Relations struct { field.RelationField User struct { field.RelationField } TargetUser struct { field.RelationField } } Pronouns struct { field.RelationField User struct { field.RelationField } } Roles struct { field.RelationField User struct { field.RelationField } Role struct { field.RelationField } } AuthMethods struct { field.RelationField User 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 Icon 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"), Creator: struct { field.RelationField Icon struct { field.RelationField } Background struct { field.RelationField } Banner struct { field.RelationField } RemoteInfo struct { field.RelationField User struct { field.RelationField } } InfoFields struct { field.RelationField User struct { field.RelationField } } BeingTypes struct { field.RelationField User struct { field.RelationField } } Tags struct { field.RelationField User struct { field.RelationField } } Relations struct { field.RelationField User struct { field.RelationField } TargetUser struct { field.RelationField } } Pronouns struct { field.RelationField User struct { field.RelationField } } Roles struct { field.RelationField User struct { field.RelationField } Role struct { field.RelationField } } AuthMethods struct { field.RelationField User struct { field.RelationField } } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator", "models.User"), Icon: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Icon", "models.MediaMetadata"), }, Background: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Background", "models.MediaMetadata"), }, Banner: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Banner", "models.MediaMetadata"), }, RemoteInfo: struct { field.RelationField User struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.RemoteInfo", "models.UserRemoteLinks"), User: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.RemoteInfo.User", "models.User"), }, }, InfoFields: struct { field.RelationField User struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.InfoFields", "models.UserInfoField"), User: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.InfoFields.User", "models.User"), }, }, BeingTypes: struct { field.RelationField User struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.BeingTypes", "models.UserToBeing"), User: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.BeingTypes.User", "models.User"), }, }, Tags: struct { field.RelationField User struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Tags", "models.UserToTag"), User: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Tags.User", "models.User"), }, }, Relations: struct { field.RelationField User struct { field.RelationField } TargetUser struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Relations", "models.UserToUserRelation"), User: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Relations.User", "models.User"), }, TargetUser: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Relations.TargetUser", "models.User"), }, }, Pronouns: struct { field.RelationField User struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Pronouns", "models.UserToPronoun"), User: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Pronouns.User", "models.User"), }, }, Roles: struct { field.RelationField User struct { field.RelationField } Role struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Roles", "models.UserToRole"), User: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Roles.User", "models.User"), }, Role: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.Roles.Role", "models.Role"), }, }, AuthMethods: struct { field.RelationField User struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.AuthMethods", "models.UserAuthMethod"), User: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.Creator.AuthMethods.User", "models.User"), }, }, }, 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 Icon 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 Icon 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 Icon struct { field.RelationField } }{ RelationField: field.NewRelation("AttachmentRelations.Note.EmoteRelations.Emote.Server", "models.RemoteServer"), Icon: struct { field.RelationField }{ RelationField: field.NewRelation("AttachmentRelations.Note.EmoteRelations.Emote.Server.Icon", "models.MediaMetadata"), }, }, }, }, 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.Creator = noteBelongsToCreator{ db: db.Session(&gorm.Session{}), RelationField: field.NewRelation("Creator", "models.User"), } _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 Creator noteBelongsToCreator 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, 17) 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 Creator struct { field.RelationField Icon struct { field.RelationField } Background struct { field.RelationField } Banner struct { field.RelationField } RemoteInfo struct { field.RelationField User struct { field.RelationField } } InfoFields struct { field.RelationField User struct { field.RelationField } } BeingTypes struct { field.RelationField User struct { field.RelationField } } Tags struct { field.RelationField User struct { field.RelationField } } Relations struct { field.RelationField User struct { field.RelationField } TargetUser struct { field.RelationField } } Pronouns struct { field.RelationField User struct { field.RelationField } } Roles struct { field.RelationField User struct { field.RelationField } Role struct { field.RelationField } } AuthMethods struct { field.RelationField User 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 Icon 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 ¬eHasManyAttachmentRelationsTx{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 ¬eHasManyEmoteRelationsTx{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 ¬eHasManyPingRelationsTx{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 ¬eHasManyTagsTx{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 noteBelongsToCreator struct { db *gorm.DB field.RelationField } func (a noteBelongsToCreator) Where(conds ...field.Expr) *noteBelongsToCreator { 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 noteBelongsToCreator) WithContext(ctx context.Context) *noteBelongsToCreator { a.db = a.db.WithContext(ctx) return &a } func (a noteBelongsToCreator) Session(session *gorm.Session) *noteBelongsToCreator { a.db = a.db.Session(session) return &a } func (a noteBelongsToCreator) Model(m *models.Note) *noteBelongsToCreatorTx { return ¬eBelongsToCreatorTx{a.db.Model(m).Association(a.Name())} } type noteBelongsToCreatorTx struct{ tx *gorm.Association } func (a noteBelongsToCreatorTx) Find() (result *models.User, err error) { return result, a.tx.Find(&result) } func (a noteBelongsToCreatorTx) Append(values ...*models.User) (err error) { targetValues := make([]interface{}, len(values)) for i, v := range values { targetValues[i] = v } return a.tx.Append(targetValues...) } func (a noteBelongsToCreatorTx) Replace(values ...*models.User) (err error) { targetValues := make([]interface{}, len(values)) for i, v := range values { targetValues[i] = v } return a.tx.Replace(targetValues...) } func (a noteBelongsToCreatorTx) Delete(values ...*models.User) (err error) { targetValues := make([]interface{}, len(values)) for i, v := range values { targetValues[i] = v } return a.tx.Delete(targetValues...) } func (a noteBelongsToCreatorTx) Clear() error { return a.tx.Clear() } func (a noteBelongsToCreatorTx) 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 }