Ниже приведен запрос, который я использую, чтобы получить сгенерированную формулу, основанную на группе concat, поэтому я могу применить одну и ту же формулу к другой таблице. он работает нормально для одного идентификатора, так как не работает для идентификатора, разделенного запятыми
/ * id_val = '6,7'; // задано в параметре sp * /
SET @query = (SELECT GROUP_CONCAT(CONCAT('(SUM(',column_name_table,') / sum(count_of_x) ) * 100
as ',kpi_display_name,' ') ) FROM `formula_table` WHERE id IN (id_val) );
SELECT @query;
Где count_of_x - это состояние c value; Аргумент column_name_table - это поле в формуле_таблицы
, но приведенный выше запрос возвращает одно значение;
структура таблицы в виде
CREATE TABLE `formula_table` (
`id` int NOT NULL AUTO_INCREMENT,
`column_name_table` varchar(255) DEFAULT NULL
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=84 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
insert into `formula_table`(`id`,`column_name_table`) values
(5,'higest_record'),
(6,'higest_salary'),
(7,'higest_employee'),
(9,'higest_x');