Files
quyun-v2/backend/database/models/content_assets.gen.go
Rogee 1da84f2af3 feat: add TenantLedger model and query generation
- Introduced TenantLedger model with fields for managing tenant transactions, including ID, TenantID, UserID, OrderID, transaction Type, Amount, and balance details.
- Implemented CRUD operations for TenantLedger with methods for Create, Update, Delete, and Reload.
- Generated query methods for TenantLedger to facilitate database interactions, including filtering, pagination, and aggregation functions.
- Established relationships with Order model for foreign key references.
2025-12-18 13:12:26 +08:00

66 lines
4.0 KiB
Go
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
// Code generated by go.ipao.vip/gen. DO NOT EDIT.
// Code generated by go.ipao.vip/gen. DO NOT EDIT.
// Code generated by go.ipao.vip/gen. DO NOT EDIT.
package models
import (
"context"
"time"
"quyun/v2/pkg/consts"
"go.ipao.vip/gen"
)
const TableNameContentAsset = "content_assets"
// ContentAsset mapped from table <content_assets>
type ContentAsset struct {
ID int64 `gorm:"column:id;type:bigint;primaryKey;autoIncrement:true;comment:主键ID自增" json:"id"` // 主键ID自增
TenantID int64 `gorm:"column:tenant_id;type:bigint;not null;comment:租户ID多租户隔离必须与 content_id、asset_id 所属租户一致" json:"tenant_id"` // 租户ID多租户隔离必须与 content_id、asset_id 所属租户一致
UserID int64 `gorm:"column:user_id;type:bigint;not null;comment:用户ID操作人/绑定人;用于审计(通常为租户管理员或作者)" json:"user_id"` // 用户ID操作人/绑定人;用于审计(通常为租户管理员或作者)
ContentID int64 `gorm:"column:content_id;type:bigint;not null;comment:内容ID关联 contents.id用于查询内容下资源列表" json:"content_id"` // 内容ID关联 contents.id用于查询内容下资源列表
AssetID int64 `gorm:"column:asset_id;type:bigint;not null;comment:资源ID关联 media_assets.id用于查询资源归属内容" json:"asset_id"` // 资源ID关联 media_assets.id用于查询资源归属内容
Role consts.ContentAssetRole `gorm:"column:role;type:character varying(32);not null;default:main;comment:资源角色main/cover/previewpreview 必须为独立资源以满足禁下载与防绕过" json:"role"` // 资源角色main/cover/previewpreview 必须为独立资源以满足禁下载与防绕过
Sort int32 `gorm:"column:sort;type:integer;not null;comment:排序:同一 role 下的展示顺序,数值越小越靠前" json:"sort"` // 排序:同一 role 下的展示顺序,数值越小越靠前
CreatedAt time.Time `gorm:"column:created_at;type:timestamp with time zone;not null;default:now();comment:创建时间:默认 now();用于审计" json:"created_at"` // 创建时间:默认 now();用于审计
UpdatedAt time.Time `gorm:"column:updated_at;type:timestamp with time zone;not null;default:now();comment:更新时间:默认 now();更新 sort/role 时写入" json:"updated_at"` // 更新时间:默认 now();更新 sort/role 时写入
}
// Quick operations without importing query package
// Update applies changed fields to the database using the default DB.
func (m *ContentAsset) Update(ctx context.Context) (gen.ResultInfo, error) {
return Q.ContentAsset.WithContext(ctx).Updates(m)
}
// Save upserts the model using the default DB.
func (m *ContentAsset) Save(ctx context.Context) error {
return Q.ContentAsset.WithContext(ctx).Save(m)
}
// Create inserts the model using the default DB.
func (m *ContentAsset) Create(ctx context.Context) error {
return Q.ContentAsset.WithContext(ctx).Create(m)
}
// Delete removes the row represented by the model using the default DB.
func (m *ContentAsset) Delete(ctx context.Context) (gen.ResultInfo, error) {
return Q.ContentAsset.WithContext(ctx).Delete(m)
}
// ForceDelete permanently deletes the row (ignores soft delete) using the default DB.
func (m *ContentAsset) ForceDelete(ctx context.Context) (gen.ResultInfo, error) {
return Q.ContentAsset.WithContext(ctx).Unscoped().Delete(m)
}
// Reload reloads the model from database by its primary key and overwrites current fields.
func (m *ContentAsset) Reload(ctx context.Context) error {
fresh, err := Q.ContentAsset.WithContext(ctx).GetByID(m.ID)
if err != nil {
return err
}
*m = *fresh
return nil
}