我在phpmyadmin中创建了一个存储函数,该函数跨多个字段进行计算以得出总体价值。我正在使用一个函数,因为需要在多个脚本中多次使用计算,因此,据我所知,这是最有效的方法,可以最大程度地减少代码更新。
我已经测试了该函数,并且它在提供输出方面起作用,但是当我将其与查询结合使用时,它会提供整个查询结果的汇总数字,而不是每行的特定数字:
功能代码:
BEGIN
DECLARE Output_needed INT(7);
SET Output_needed = (select SUM(Col1+Col2+Col3) from table1);
RETURN (Output_needed);
END
SQL查询:
Select ID, function_name(), Col1, Col2, Col3 from table1
必需的查询输出
ID Function Returns *Output_needed* Col1 Col2 Col3
1 100 *10* 4 4 2
2 100 *50* 10 20 20
3 100 *5* 1 2 2
4 100 *15* 10 2 3
5 100 *20* 6 3 1
有人可以告诉我我要去哪里了吗?我认为我错过了某个步骤,但似乎无法弄清楚。
谢谢!
答案 0 :(得分:0)
函数select查询没有获取单行结果的条件。因此,我只添加了一个字段供条件使用。
功能:
DELIMITER $$
CREATE DEFINER=`root`@`localhost` FUNCTION `function_name`(pk_field INT) RETURNS int(11)
BEGIN
DECLARE output_needed INT;
SELECT SUM(Col1+Col2+Col3) INTO output_needed FROM table1 WHERE pk_field_name = pk_field;
RETURN output_needed;
END$$
DELIMITER ;
选择查询:
Select ID, function_name(pk_field_name), Col1, Col2, Col3 from table1