如何将数组编码为URL参数,在PHP中提取并作为函数参数传递给Postgres


How to encode an array as URL parameter, extract in in PHP and pass to Postgres as function parameter

如果我有一个工作正常的postgres函数(类似于下面);

package."func_SetValues"(id integer, values integer[])
    DECLARE
        i integer;
    BEGIN
    FOR i IN 1..array_upper(values, 1) 
      LOOP
       EXECUTE package."func_DoStuff"(id, values[i]);
      END LOOP;
    END
    LANGUAGE 'plpgsql' VOLATILE

并且,一个PHP脚本doStuff.PHP调用这个函数,该函数接受并使用这些值作为url编码的参数。

$dbconn = pg_connect("host=192.168.1.222 port=5432 dbname=betya user=betya_user password=bettyboo")
    or die('Could not connect: ' . pg_last_error());
$query = 'SELECT * FROM package."func_SetValues"($1, $2)';
$result=pg_prepare($dbconn, "qy", $query);
$paramater1=$_REQUEST['id'];    
$paramater2=$_REQUEST['arr']; 
$result=pg_execute($dbconn, "qy", array($paramater1, $paramater2));
while($e=pg_fetch_assoc($result))
$output[]=$e;
print(json_encode($output));
pg_free_result($result);
pg_close($dbconn);

为了测试PHP脚本,以下URL是否正确地对数组"arr"进行了编码,使PHP可以"请求"这些值,并可以将其传递给它所理解的postgres?或者,脚本中是否需要进一步的功能才能正确传递给pg_execute命令?

http://192.168.1.50/server/doStuff.php?id=1790&arr[]=1788&arr[]=1790&arr[]=1805

是的,需要进一步的代码。数组必须经过非平凡的转换才能作为参数传递,因为PG希望它以文档中描述的文本形式:http://www.postgresql.org/docs/current/static/arrays.html#ARRAYS-IO

在另一个问题中:PHP数组到postgres数组,一个具有这种效果的PHP函数已经提交给S.O.,它可能正是你所需要的(而且越来越好,因为它支持递归数组)。