如何分解存储的函数输出phpmyadmin

时间:2018-10-09 12:37:01

标签: mysql stored-functions

我在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

有人可以告诉我我要去哪里了吗?我认为我错过了某个步骤,但似乎无法弄清楚。

谢谢!

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