package data_stat

import (
	"eta_gn/eta_api/global"
	"github.com/rdlucklib/rdluck_tools/paging"
	"time"
)

// EdbInfoUpdateLog 指标更新/刷新日志列表
//type EdbInfoUpdateLog struct {
//	Id                     uint64    `orm:"column(id);pk"`
//	EdbInfoId              int       `description:"指标ID"`
//	SourceName             string    `description:"来源名称"`
//	Source                 int       `description:"来源id"`
//	EdbCode                string    `description:"指标编码"`
//	EdbName                string    `description:"指标名称"`
//	EdbNameSource          string    `description:"指标名称来源"`
//	Frequency              string    `description:"频率"`
//	Unit                   string    `description:"单位"`
//	StartDate              string    `description:"起始日期"`
//	EndDate                string    `description:"终止日期"`
//	SysUserId              int       `description:"创建人ID"`
//	SysUserRealName        string    `description:"创建人姓名"`
//	UniqueCode             string    `description:"指标唯一编码"`
//	EdbCreateTime          time.Time `description:"指标创建时间"`
//	EdbModifyTime          time.Time `description:"指标修改时间"`
//	CreateTime             time.Time `description:"创建时间"`
//	UpdateSysUserId        int       `description:"变更人ID"`
//	UpdateSysUserRealName  string    `description:"变更人姓名"`
//	LatestDate             string    `description:"数据最新日期"`
//	LatestValue            float64   `description:"数据最新值"`
//	TerminalCode           string    `description:"终端编码,用于配置在机器上"`
//	ErDataUpdateDate       string    `description:"本次更新,数据发生变化的最早日期"`
//	UpdateResult           int       `description:"本次刷新操作结果:1成功,2失败"`
//	UpdateFailedReason     string    `description:"刷新失败原因"`
//	DataUpdateResult       int       `description:"数据更新结果:1成功,2失败"`
//	DataUpdateFailedReason string    `description:"数据未正常更新原因"`
//	DataUpdateTime         string    `description:"数据更新时间"`
//	IsSourceRefresh        int       `description:"是否为终端刷新到数据源的刷新操作:0否,1是"`
//	UpdateType             int       `description:"变更类型,0:数据明细变更,1:基础信息变更, 2:新增指标"`
//}

type EdbInfoUpdateLog struct {
	Id                     uint64    `gorm:"primaryKey;unique;column:id;type:bigint(20) unsigned;not null"` // 自增id
	EdbInfoId              int       `gorm:"column:edb_info_id;type:int(11);not null"`                      // 指标id
	SourceName             string    `gorm:"column:source_name;type:varchar(100)"`                          // 来源名称
	Source                 int       `gorm:"column:source;type:tinyint(4)"`                                 // 来源:1:同花顺,2:wind,3:彭博,4:指标运算,5:累计值转月,6:同比值,7:同差值,8:N数值移动平均计算,9:手工指标,10:隆众,11:有色,12:环比值,13:环差值,14:变频,15:钢联
	EdbCode                string    `gorm:"column:edb_code;type:varchar(255);not null;default:''"`         // 指标编码
	EdbName                string    `gorm:"column:edb_name;type:varchar(255);default:''"`                  // 指标名称
	EdbNameSource          string    `gorm:"column:edb_name_source;type:varchar(255);default:''"`           // 指标名称_来源
	Frequency              string    `gorm:"column:frequency;type:varchar(20);default:''"`                  // 频度
	Unit                   string    `gorm:"column:unit;type:varchar(20);default:''"`                       // 单位
	StartDate              string    `gorm:"column:start_date;type:date"`                                   // 更新开始日期
	EndDate                string    `gorm:"column:end_date;type:date"`                                     // 更新结束日期
	SysUserId              int       `gorm:"column:sys_user_id;type:int(11)"`                               // 创建人
	SysUserRealName        string    `gorm:"column:sys_user_real_name;type:varchar(100)"`                   // 创建人姓名
	UpdateSysUserId        int       `gorm:"column:update_sys_user_id;type:int(11)"`                        // 变更人
	UpdateSysUserRealName  string    `gorm:"column:update_sys_user_real_name;type:varchar(100)"`            // 变更人姓名
	EdbCreateTime          time.Time `gorm:"column:edb_create_time;type:datetime"`                          // 指标创建时间
	EdbModifyTime          time.Time `gorm:"column:edb_modify_time;type:datetime"`                          // 指标修改时间
	UniqueCode             string    `gorm:"column:unique_code;type:varchar(50);default:''"`                // 唯一编码
	LatestDate             string    `gorm:"column:latest_date;type:date"`                                  // 数据最新日期
	LatestValue            float64   `gorm:"column:latest_value;type:double"`                               // 数据最新值
	TerminalCode           string    `gorm:"column:terminal_code;type:varchar(255);default:''"`             // 终端编码,用于配置在机器上
	CreateTime             time.Time `gorm:"index:create_time_idx;column:create_time;type:datetime"`        // 创建时间,即指标刷新/更新操作时间点
	DataUpdateTime         string    `gorm:"column:data_update_time;type:datetime"`                         // 最近一次数据发生变化的时间
	ErDataUpdateDate       string    `gorm:"column:er_data_update_date;type:date"`                          // 本次更新,数据发生变化的最早日期
	UpdateResult           int       `gorm:"column:update_result;type:int(11)"`                             // 本次刷新操作结果:1成功,2失败
	UpdateFailedReason     string    `gorm:"column:update_failed_reason;type:varchar(255)"`                 // 刷新失败原因
	DataUpdateResult       int       `gorm:"column:data_update_result;type:int(11);not null;default:0"`     // 数据更新结果:1成功,2失败,
	DataUpdateFailedReason string    `gorm:"column:data_update_failed_reason;type:varchar(255)"`            // 数据未正常更新原因,
	IsSourceRefresh        int       `gorm:"column:is_source_refresh;type:int(11);not null;default:0"`      // 是否为终端刷新到数据源的刷新操作:0否,1是
	UpdateType             int       `gorm:"column:update_type;type:tinyint(4);not null;default:0"`         // 变更类型,0:数据明细变更,1:基础信息变更, 2:新增指标
}

type EdbInfoUpdateLogItem struct {
	Id                    uint64 `orm:"column(id);pk"`
	EdbInfoId             int    `description:"指标ID"`
	SourceName            string `description:"来源名称"`
	Source                int    `description:"来源id"`
	EdbCode               string `description:"指标编码"`
	EdbName               string `description:"指标名称"`
	EdbNameSource         string `description:"指标名称来源"`
	Frequency             string `description:"频率"`
	Unit                  string `description:"单位"`
	StartDate             string `description:"起始日期"`
	EndDate               string `description:"终止日期"`
	SysUserId             int    `description:"创建人ID"`
	SysUserRealName       string `description:"创建人姓名"`
	UpdateSysUserId       int    `description:"变更人ID"`
	UpdateSysUserRealName string `description:"变更人姓名"`
	CreateTime            string
	UniqueCode            string  `description:"指标唯一编码"`
	LatestDate            string  `description:"数据最新日期"`
	LatestValue           float64 `description:"数据最新值"`
	TerminalCode          string  `description:"终端编码,用于配置在机器上"`
	DataUpdateTime        string  `description:"最近一次数据发生变化的时间"`
	ErDataUpdateDate      string  `description:"本次更新,数据发生变化的最早日期"`
	UpdateType            int     `description:"变更类型,0:数据明细变更,1:基础信息变更, 2:新增指标"`
}

func AddEdbUpdateLog(item *EdbInfoUpdateLog) (lastId int64, err error) {
	//o := orm.NewOrmUsingDB("data")
	//lastId, err = o.Insert(item)
	err = global.DmSQL["data"].Create(item).Error
	lastId = int64(item.Id)
	return
}

type GetEdbUpdateLogResp struct {
	List   []*EdbInfoUpdateLogItem
	Paging *paging.PagingItem
}

func GetEdbUpdateLogByCondition(condition string, pars []interface{}, orderStr string, pageSize, startSize int) (item []*EdbInfoUpdateLog, err error) {
	//o := orm.NewOrmUsingDB("data")
	sql := ` SELECT * FROM edb_info_update_log WHERE 1=1 `
	if condition != "" {
		sql += condition
	}
	if orderStr != "" {
		sql += orderStr
	} else {
		sql += ` ORDER BY create_time DESC, id DESC `
	}

	sql += ` LIMIT ?,? `
	//_, err = o.Raw(sql, pars...).QueryRows(&item)

	pars = append(pars, startSize)
	pars = append(pars, pageSize)
	err = global.DmSQL["data"].Raw(sql, pars...).Find(&item).Error
	return
}

// GetEdbUpdateLogCount
func GetEdbUpdateLogCount(condition string, pars []interface{}) (count int, err error) {
	//o := orm.NewOrmUsingDB("data")
	sql := ` SELECT count(*) FROM edb_info_update_log WHERE 1=1 `
	if condition != "" {
		sql += condition
	}
	//err = o.Raw(sql, pars).QueryRow(&count)
	err = global.DmSQL["data"].Raw(sql, pars...).Scan(&count).Error
	return
}