Roc 6 天之前
父节点
当前提交
db64b99694
共有 1 个文件被更改,包括 154 次插入0 次删除
  1. 154 0
      models/rag/rag_eta_report.go

+ 154 - 0
models/rag/rag_eta_report.go

@@ -0,0 +1,154 @@
+package rag
+
+import (
+	"database/sql"
+	"eta/eta_api/global"
+	"eta/eta_api/utils"
+	"fmt"
+	"time"
+)
+
+// RagEtaReport eta报告
+type RagEtaReport struct {
+	RagEtaReportID  int       `gorm:"primaryKey;column:rag_eta_report_id" json:"-"`
+	ReportID        int       `gorm:"column:report_id" json:"reportId"`                // 报告id
+	ReportChapterID int       `gorm:"column:report_chapter_id" json:"reportChapterId"` // 报告章节id
+	Title           string    `gorm:"column:title" json:"title"`                       // 报告标题(完整标题,含期数)
+	Author          string    `gorm:"column:author" json:"author"`                     // 作者
+	TextContent     string    `gorm:"column:text_content" json:"textContent"`          // 报告内容(去除html)
+	VectorKey       string    `gorm:"column:vector_key" json:"vectorKey"`              // 向量库的key
+	PublishTime     time.Time `gorm:"column:publish_time" json:"publishTime"`          // 发布时间
+	ModifyTime      time.Time `gorm:"column:modify_time" json:"modifyTime"`            // 修改时间
+	CreateTime      time.Time `gorm:"column:create_time" json:"createTime"`            // 新增时间
+}
+
+// TableName get sql table name.获取数据库表名
+func (m *RagEtaReport) TableName() string {
+	return "rag_eta_report"
+}
+
+// RagEtaReportColumns get sql column name.获取数据库列名
+var RagEtaReportColumns = struct {
+	RagEtaReportID  string
+	ReportID        string
+	ReportChapterID string
+	Title           string
+	Author          string
+	TextContent     string
+	VectorKey       string
+	PublishTime     string
+	ModifyTime      string
+	CreateTime      string
+}{
+	RagEtaReportID:  "rag_eta_report_id",
+	ReportID:        "report_id",
+	ReportChapterID: "report_chapter_id",
+	Title:           "title",
+	Author:          "author",
+	TextContent:     "text_content",
+	VectorKey:       "vector_key",
+	PublishTime:     "publish_time",
+	ModifyTime:      "modify_time",
+	CreateTime:      "create_time",
+}
+
+type RagEtaReportView struct {
+	RagEtaReportID  int       `gorm:"primaryKey;column:rag_eta_report_id" json:"-"`
+	ReportID        int       `gorm:"column:report_id" json:"reportId"`                // 报告id
+	ReportChapterID int       `gorm:"column:report_chapter_id" json:"reportChapterId"` // 报告章节id
+	Title           string    `gorm:"column:title" json:"title"`                       // 报告标题(完整标题,含期数)
+	Author          string    `gorm:"column:author" json:"author"`                     // 作者
+	TextContent     string    `gorm:"column:text_content" json:"textContent"`          // 报告内容(去除html)
+	VectorKey       string    `gorm:"column:vector_key" json:"vectorKey"`              // 向量库的key
+	PublishTime     time.Time `gorm:"column:publish_time" json:"publishTime"`          // 发布时间
+	ModifyTime      time.Time `gorm:"column:modify_time" json:"modifyTime"`            // 修改时间
+	CreateTime      time.Time `gorm:"column:create_time" json:"createTime"`            // 新增时间
+}
+
+func (m *RagEtaReport) ToView() RagEtaReportView {
+	var publishTime, modifyTime, createTime string
+
+	if !m.PublishTime.IsZero() {
+		publishTime = m.PublishTime.Format(utils.FormatDateTime)
+	}
+	if !m.CreateTime.IsZero() {
+		createTime = m.CreateTime.Format(utils.FormatDateTime)
+	}
+	if !m.ModifyTime.IsZero() {
+		modifyTime = m.ModifyTime.Format(utils.FormatDateTime)
+	}
+	return RagEtaReportView{
+		RagEtaReportID:  0,
+		ReportID:        0,
+		ReportChapterID: 0,
+		Title:           "",
+		Author:          "",
+		TextContent:     "",
+		VectorKey:       "",
+		PublishTime:     time.Time{},
+		ModifyTime:      time.Time{},
+		CreateTime:      time.Time{},
+	}
+}
+
+func (m *RagEtaReport) ListToViewList(list []*RagEtaReport) (RagEtaReportViewList []RagEtaReportView) {
+	RagEtaReportViewList = make([]RagEtaReportView, 0)
+
+	for _, v := range list {
+		RagEtaReportViewList = append(RagEtaReportViewList, v.ToView())
+	}
+	return
+}
+
+func (m *RagEtaReport) Create() (err error) {
+	err = global.DbMap[utils.DbNameAI].Create(&m).Error
+
+	return
+}
+
+func (m *RagEtaReport) Update(updateCols []string) (err error) {
+	err = global.DbMap[utils.DbNameAI].Select(updateCols).Updates(&m).Error
+
+	return
+}
+
+func (m *RagEtaReport) GetById(id int) (item *RagEtaReport, err error) {
+	err = global.DbMap[utils.DbNameAI].Where(fmt.Sprintf("%s = ?", RagEtaReportColumns.RagEtaReportID), id).First(&item).Error
+
+	return
+}
+
+func (m *RagEtaReport) GetListByCondition(field, condition string, pars []interface{}, startSize, pageSize int) (items []*RagEtaReport, err error) {
+	if field == "" {
+		field = "*"
+	}
+	sqlStr := fmt.Sprintf(`SELECT %s FROM %s WHERE 1=1 AND is_deleted=0 %s  order by article_create_time desc,wechat_article_id desc LIMIT ?,?`, field, m.TableName(), condition)
+	pars = append(pars, startSize, pageSize)
+	err = global.DbMap[utils.DbNameAI].Raw(sqlStr, pars...).Find(&items).Error
+
+	return
+}
+
+func (m *RagEtaReport) GetCountByCondition(condition string, pars []interface{}) (total int, err error) {
+	var intNull sql.NullInt64
+	sqlStr := fmt.Sprintf(`SELECT COUNT(1) total FROM %s WHERE 1=1 AND is_deleted=0 %s`, m.TableName(), condition)
+	err = global.DbMap[utils.DbNameAI].Raw(sqlStr, pars...).Scan(&intNull).Error
+	if err == nil && intNull.Valid {
+		total = int(intNull.Int64)
+	}
+
+	return
+}
+
+func (m *RagEtaReport) GetPageListByCondition(condition string, pars []interface{}, startSize, pageSize int) (total int, items []*RagEtaReport, err error) {
+
+	total, err = m.GetCountByCondition(condition, pars)
+	if err != nil {
+		return
+	}
+	if total > 0 {
+		items, err = m.GetListByCondition(`wechat_article_id,wechat_platform_id,fake_id,title,link,cover_url,description,country,province,city,article_create_time,modify_time,create_time`, condition, pars, startSize, pageSize)
+	}
+
+	return
+}