修改黄金指标接口

This commit is contained in:
lai
2023-12-05 19:54:16 +08:00
parent dfc4a849f6
commit 97e453d880
2 changed files with 36 additions and 68 deletions

View File

@@ -81,57 +81,29 @@ export async function listgoldData(query: Record<string, any>) {
/** /**
* 查询黄金指标数据 * 查询黄金指标数据
* @param query 查询参数 * @param query 查询参数
* @returns object * @returns object
*/ */
export async function goldData(query: Record<string, any>) { export async function goldData(query: Record<string, any>) {
// 发起请求
let insertKpiId: string[]=[];
let insertWhere: string[]=[];
query.goldArr.forEach((item: any)=> {
insertKpiId.push(`SUM(CASE WHEN kpi_id = '${item}' THEN value ELSE 0 END) AS \`${item}\``);
insertWhere.push(`'${item}'`);
})
const result = await request({ const result = await request({
url: `/api/rest/databaseManagement/v1/select/omc_db/gold_kpi`, url: `/ne/kpi/data`,
method: 'get', method: 'get',
params: { params: {
rowsSQL:`SELECT CONCAT(DATE_FORMAT(start_time, '%Y-%m-%d %H:'), LPAD(FLOOR(MINUTE(start_time) / ${query.particle}) * ${query.particle}, 2, '0'), ':00') AS time_interval,`+ neType:query.neType[0],
insertKpiId.join(",")+ neId:query.neType[1],
" FROM gold_kpi"+ startTime:query.beginTime,
` WHERE ne_type='${query.neType[0]}' and kpi_id in (${insertWhere.join(",")}) and start_time BETWEEN '${query.beginTime}' AND '${query.endTime}'`+ endTime:query.endTime,
` GROUP BY DATE_FORMAT(start_time, '%Y-%m-%d %H:'), FLOOR(MINUTE(start_time) / ${query.particle})`+ interval:query.particle
" ORDER BY start_time",
}, },
timeout: 60_000, timeout: 60_000,
}); });
// 解析数据
if (result.code === RESULT_CODE_SUCCESS) {
const data: DataList = {
total: 0,
rows: [],
code: result.code,
msg: result.msg,
};
result.data.data.forEach((item: any) => {
const itemData = item['gold_kpi'];
if (Array.isArray(itemData)) {
if (itemData.length === 1 && itemData[0]['total'] >= 0) {
data.total = itemData[0]['total'];
} else {
data.rows = itemData.map(v => parseObjLineToHump(v));
}
}
});
return data;
}
return result; return result;
} }
/** /**
* 查询网元可用黄金指标 * 查询网元可用黄金指标
* @param neType 网元类型 * @param neType 网元类型
@@ -140,19 +112,11 @@ export async function goldData(query: Record<string, any>) {
export async function getGoldTitleByNE(neType: string) { export async function getGoldTitleByNE(neType: string) {
// 发起请求 // 发起请求
const result = await request({ const result = await request({
url: `/api/rest/databaseManagement/v1/elementType/omc_db/objectType/kpi_title`, url: `/ne/kpi/title`,
method: 'get', method: 'get',
params: { params:{neType}
SQL: `select * from kpi_title where ne_type = '${neType}' `,
},
}); });
// 解析数据 // 解析数据
if (result.code === RESULT_CODE_SUCCESS && Array.isArray(result.data.data)) {
let data = result.data.data[0];
return Object.assign(result, {
data: parseObjLineToHump(data['kpi_title']),
});
}
return result; return result;
} }

View File

@@ -116,6 +116,7 @@ function findTitleByKey(key: string): string | undefined {
const item = state.designTreeData.find(item => item.key === key); const item = state.designTreeData.find(item => item.key === key);
return item ? item.title : undefined; return item ? item.title : undefined;
} }
/**筛选条件进行制图 */ /**筛选条件进行制图 */
function fnDesign() { function fnDesign() {
if (!queryRangePicker.value) { if (!queryRangePicker.value) {
@@ -128,10 +129,11 @@ function fnDesign() {
let goldYData: any = []; let goldYData: any = [];
let hideAllArr: any = []; let hideAllArr: any = [];
goldData(queryParams).then(res => { goldData(queryParams).then(res => {
if (res.code === RESULT_CODE_SUCCESS && Array.isArray(res.rows)) { console.log(res.data)
if (res.rows.length > 0) { if (res.code === RESULT_CODE_SUCCESS) {
goldXDate = res.rows.map(item => item.timeInterval); if (res.data.length > 0) {
goldYData = Object.keys(res.rows[0]) goldXDate = res.data.map((item:any) => item.timeInterval);
goldYData = Object.keys(res.data[0])
.filter(key => key !== 'timeInterval') .filter(key => key !== 'timeInterval')
.map(key => { .map(key => {
if (!queryParams.goldArr.includes(key)) hideAllArr[key] = false; if (!queryParams.goldArr.includes(key)) hideAllArr[key] = false;
@@ -139,15 +141,17 @@ function fnDesign() {
if (queryParams.goldArr.includes(key)) if (queryParams.goldArr.includes(key))
return { return {
name: title, name: title,
data: res.rows.map((item: any) => parseInt(item[key])), data: res.data.map((item: any) => parseInt(item[key])),
}; };
}); });
} else { } else {
state.designTreeData.forEach((item: any) => {
goldYData.push({name:item.title,data:[]});
});
message.warning({ message.warning({
content: t('views.perfManage.goldTarget.nullTip'), content: t('views.perfManage.goldTarget.nullTip'),
duration: 2, duration: 2,
}); });
return false;
} }
// 图标参数 // 图标参数
@@ -255,10 +259,7 @@ onMounted(() => {
<a-row :gutter="16"> <a-row :gutter="16">
<a-col :span="8"> <a-col :span="8">
<!-- 命令导航 --> <!-- 命令导航 -->
<a-card <a-card size="small" :bordered="false">
size="small"
:bordered="false"
>
<a-form name="queryParamsFrom" layout="horizontal"> <a-form name="queryParamsFrom" layout="horizontal">
<a-form-item <a-form-item
name="neType" name="neType"
@@ -330,7 +331,10 @@ onMounted(() => {
<a-col :span="16"> <a-col :span="16">
<a-card :bordered="false" :body-style="{ marginBottom: '24px' }"> <a-card :bordered="false" :body-style="{ marginBottom: '24px' }">
<!-- 插槽-卡片左侧侧 --> <!-- 插槽-卡片左侧侧 -->
<template #title>{{ t('views.perfManage.goldTarget.kpiTitle') }}</template> <template #title>{{
t('views.perfManage.goldTarget.kpiTitle')
}}</template>
<div class="chart"> <div class="chart">
<ChartLine <ChartLine
:option="chartsOption.perfChart" :option="chartsOption.perfChart"