package data_stat import ( "eta_gn/eta_api/global" "github.com/rdlucklib/rdluck_tools/paging" "time" ) // EdbInfoUpdateStat 指标更新/刷新 汇总表(数据源明细表) //type EdbInfoUpdateStat 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 // UpdateTime string `description:"刷新时间"` // LatestDate string `description:"数据最新日期"` // LatestValue float64 `description:"数据最新值"` // TerminalCode string `description:"终端编码,用于配置在机器上"` // ErDataUpdateDate string `description:"本次更新,数据发生变化的最早日期"` // DataUpdateResult int `description:"数据更新结果:1成功,2失败"` // DataUpdateFailedReason string `description:"数据未正常更新原因"` // DataUpdateTime string `description:"数据更新时间"` // UpdateResult int `description:"本次刷新操作结果:1成功,2失败"` // UpdateFailedReason string `description:"刷新失败原因"` // ModifyTime string `description:"修改时间"` // IsAdd int8 `description:"是否是当日新增的指标:1是,2否"` // NeedRefresh int8 `description:"今日是否需要定时刷新,1需要,0不需要"` //todo 确认该字段 // HasRefresh int8 `description:"今日是否已刷新,1是,0否"` //} type EdbInfoUpdateStat 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)"` // 创建人姓名 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"` // 创建时间 ModifyTime time.Time `gorm:"column:modify_time;type:datetime"` // 修改时间 UpdateTime string `gorm:"column:update_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)"` // 当天数据未正常刷新原因 IsAdd int8 `gorm:"column:is_add;type:tinyint(4);not null;default:0"` // 是否是当日新增的指标:1是,2否 NeedRefresh int8 `gorm:"column:need_refresh;type:tinyint(4);not null;default:0"` // 今日是否需要刷新,1需要,0不需要 HasRefresh int8 `gorm:"column:has_refresh;type:tinyint(4);not null;default:0"` // 今日是否已刷新,1是,0否 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)"` // 数据未正常更新原因, } type EdbInfoUpdateStatItem 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:"起始日期"` SysUserId int `description:"创建人ID"` SysUserRealName string `description:"创建人姓名"` LatestDate string `description:"数据最新日期"` CreateTime string `description:"创建时间"` LatestValue float64 `description:"数据最新值"` TerminalCode string `description:"终端编码,用于配置在机器上"` ErDataUpdateDate string `description:"本次更新,数据发生变化的最早日期"` DataUpdateResult int `description:"数据更新结果:1成功,2失败"` DataUpdateFailedReason string `description:"数据未正常更新原因"` DataUpdateTime string `description:"数据更新时间"` UpdateResult int `description:"本次刷新操作结果:1成功,2失败"` UpdateFailedReason string `description:"刷新失败原因"` UpdateTime string `description:"刷新时间"` IsAdd int8 `description:"是否是当日新增的指标:1是,2否"` NeedRefresh int8 `description:"今日是否需要定时刷新,1需要,0不需要"` HasRefresh int8 `description:"今日是否已刷新,1是,0否"` } type EdbInfoUpdateStatItemMore struct { EdbInfoUpdateStatItem InitSourceName string `description:"初始数据源"` } type GetEdbUpdateStatResp struct { List []*EdbInfoUpdateStatItemMore Paging *paging.PagingItem } func GetEdbUpdateStatByCondition(condition string, pars []interface{}, orderStr string, pageSize, startSize int) (item []*EdbInfoUpdateStat, err error) { //o := orm.NewOrmUsingDB("data") sql := ` SELECT * FROM edb_info_update_stat 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 } // GetEdbUpdateStatCount func GetEdbUpdateStatCount(condition string, pars []interface{}) (count int, err error) { //o := orm.NewOrmUsingDB("data") sql := ` SELECT count(*) FROM edb_info_update_stat 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 } type EdbUpdateFailedList struct { TerminalCode string `description:"终端编码,用于配置在机器上"` SourceUpdateFailedReason string `description:"从终端刷新到数据源的数据未正常刷新原因"` Frequency string `description:"频率"` SourceUpdateResult int `description:"从终端刷新到数据源的刷新结果:1成功,2失败"` Num int } type GetEdbUpdateFailedResp struct { List []*EdbUpdateFailedList Name string `description:"终端名称"` TerminalCode string `description:"终端编码,用于配置在机器上"` DirPath string `description:"终端存放的文件夹路径"` UpdateSuccessNum int `description:"今日已更新成功指标数"` UpdateFailedNum int `description:"今日已更新失败指标数"` } func GetEdbUpdateStatFailedGroupByCondition(condition string, pars []interface{}) (item []*EdbUpdateFailedList, err error) { //o := orm.NewOrmUsingDB("data") sql := `SELECT terminal_code, data_update_result as source_update_result, frequency, data_update_failed_reason as source_update_failed_reason, count(*) as num FROM edb_info_update_stat WHERE data_update_result != 0` if condition != "" { sql += condition } sql += ` GROUP BY data_update_result, frequency, data_update_failed_reason ORDER BY count(*) desc` //_, err = o.Raw(sql, pars).QueryRows(&item) err = global.DmSQL["data"].Raw(sql, pars...).Find(&item).Error return }