Files
cid/dao/cid_request_dao.go
2025-12-06 18:36:43 +08:00

82 lines
1.8 KiB
Go

package dao
import (
"cidservice/model/entity"
"context"
"github.com/gogf/gf/v2/frame/g"
)
var CIDRequest = &cidRequestDao{}
type cidRequestDao struct{}
// Create 创建CID请求记录
func (d *cidRequestDao) Create(ctx context.Context, request *entity.CidRequest) (id int64, err error) {
result, err := g.DB().Model("cid_requests").Insert(request)
if err != nil {
return 0, err
}
id, err = result.LastInsertId()
return
}
// GetHistory 获取CID请求历史
func (d *cidRequestDao) GetHistory(ctx context.Context, userId int64, page, size int) (list []*entity.CidRequest, total int64, err error) {
model := g.DB().Model("cid_requests")
// 根据用户ID筛选
model = model.Where("user_id = ?", userId)
// 获取总数
count, err := model.Count()
if err != nil {
return
}
total = int64(count)
// 分页查询
offset := (page - 1) * size
err = model.Order("created_at DESC").
Offset(offset).
Limit(size).
Scan(&list)
return
}
// GetStatistics 获取统计信息
func (d *cidRequestDao) GetStatistics(ctx context.Context, userId int64) (stats map[string]interface{}, err error) {
stats = make(map[string]interface{})
// 总请求数
totalRequests, err := g.DB().Model("cid_requests").
Where("user_id = ?", userId).
Count()
if err != nil {
return nil, err
}
stats["total_requests"] = totalRequests
// 成功请求数
successfulRequests, err := g.DB().Model("cid_requests").
Where("user_id = ? AND status = ?", userId, "completed").
Count()
if err != nil {
return nil, err
}
stats["successful_requests"] = successfulRequests
// 平均处理时间
avgProcessTime, err := g.DB().Model("cid_requests").
Fields("AVG(process_time)").
Where("user_id = ?", userId).
Value()
if err != nil {
return nil, err
}
stats["average_process_time"] = avgProcessTime
return
}