100 lines
3.2 KiB
Go
100 lines
3.2 KiB
Go
// ==========================================================================
|
||
// Code generated and maintained by GoFrame CLI tool. DO NOT EDIT.
|
||
// ==========================================================================
|
||
|
||
package internal
|
||
|
||
import (
|
||
"context"
|
||
|
||
"github.com/gogf/gf/v2/database/gdb"
|
||
"github.com/gogf/gf/v2/frame/g"
|
||
)
|
||
|
||
// AdminsDao is the data access object for the table admins.
|
||
type AdminsDao struct {
|
||
table string // table is the underlying table name of the DAO.
|
||
group string // group is the database configuration group name of the current DAO.
|
||
columns AdminsColumns // columns contains all the column names of Table for convenient usage.
|
||
handlers []gdb.ModelHandler // handlers for customized model modification.
|
||
}
|
||
|
||
// AdminsColumns defines and stores column names for the table admins.
|
||
type AdminsColumns struct {
|
||
Id string // 管理员ID
|
||
RoleId string // 角色ID
|
||
Username string // 管理员用户名
|
||
PasswordHash string // 密码哈希
|
||
RealName string // 真实姓名
|
||
Phone string // 手机号
|
||
Email string // 邮箱
|
||
Status string // 状态:1=正常,2=禁用
|
||
CreatedAt string // 创建时间
|
||
UpdatedAt string // 更新时间
|
||
DeletedAt string // 软删除时间戳
|
||
}
|
||
|
||
// adminsColumns holds the columns for the table admins.
|
||
var adminsColumns = AdminsColumns{
|
||
Id: "id",
|
||
RoleId: "role_id",
|
||
Username: "username",
|
||
PasswordHash: "password_hash",
|
||
RealName: "real_name",
|
||
Phone: "phone",
|
||
Email: "email",
|
||
Status: "status",
|
||
CreatedAt: "created_at",
|
||
UpdatedAt: "updated_at",
|
||
DeletedAt: "deleted_at",
|
||
}
|
||
|
||
// NewAdminsDao creates and returns a new DAO object for table data access.
|
||
func NewAdminsDao(handlers ...gdb.ModelHandler) *AdminsDao {
|
||
return &AdminsDao{
|
||
group: "default",
|
||
table: "admins",
|
||
columns: adminsColumns,
|
||
handlers: handlers,
|
||
}
|
||
}
|
||
|
||
// DB retrieves and returns the underlying raw database management object of the current DAO.
|
||
func (dao *AdminsDao) DB() gdb.DB {
|
||
return g.DB(dao.group)
|
||
}
|
||
|
||
// Table returns the table name of the current DAO.
|
||
func (dao *AdminsDao) Table() string {
|
||
return dao.table
|
||
}
|
||
|
||
// Columns returns all column names of the current DAO.
|
||
func (dao *AdminsDao) Columns() AdminsColumns {
|
||
return dao.columns
|
||
}
|
||
|
||
// Group returns the database configuration group name of the current DAO.
|
||
func (dao *AdminsDao) Group() string {
|
||
return dao.group
|
||
}
|
||
|
||
// Ctx creates and returns a Model for the current DAO. It automatically sets the context for the current operation.
|
||
func (dao *AdminsDao) Ctx(ctx context.Context) *gdb.Model {
|
||
model := dao.DB().Model(dao.table)
|
||
for _, handler := range dao.handlers {
|
||
model = handler(model)
|
||
}
|
||
return model.Safe().Ctx(ctx)
|
||
}
|
||
|
||
// Transaction wraps the transaction logic using function f.
|
||
// It rolls back the transaction and returns the error if function f returns a non-nil error.
|
||
// It commits the transaction and returns nil if function f returns nil.
|
||
//
|
||
// Note: Do not commit or roll back the transaction in function f,
|
||
// as it is automatically handled by this function.
|
||
func (dao *AdminsDao) Transaction(ctx context.Context, f func(ctx context.Context, tx gdb.TX) error) (err error) {
|
||
return dao.Ctx(ctx).Transaction(ctx, f)
|
||
}
|