有问题不能重新声明

时间:2012-02-14 03:56:11

标签: php mysql redeclare

我刚刚写完这个脚本并让它工作但我需要在1页上共使用它8次。它第一次工作正常,但第二次我得到:致命错误无法重新声明get_names()。我被告知这方面的方法是使用include_once,但我似乎无法弄清楚我应该怎么做。我已经尝试从代码中删除两个get_names部分,然后使用include_once命令将它们放入单独的php文件中。我得到了它的工作,但再次尝试使用该脚本两次后我得到了相同的错误。我也尝试将整个脚本放入php文件,然后使用include_once(“scriptname.php”)命令,同样的事情发生了。所以我的问题是我究竟是如何剪切这个脚本的,这样我就不会再出现这个错误了?

<?php
$db = mysql_connect('localhost', 'username', 'pass') or die("Database error");
mysql_select_db('dbname', $db);

$query = "SELECT pool FROM winners";
$result = mysql_query($query) or die(mysql_error());

while($row = mysql_fetch_array($result))
if ($row['pool'] % 2) {
echo "<h4>Result 1</h4>";
$names = get_names(1);
foreach($names as $name) {
    echo $name . "<br/>";
}
} else {
echo "<h4>Result 2</h4>";
$names = get_names(0);
foreach($names as $name) {
    echo $name . "<br/>";
}
}

function get_names($pool_result)
{
$name_array = array();

$query = "SELECT * FROM comments WHERE commentid % 2 = $pool_result";
$result = mysql_query($query);

while ($row = mysql_fetch_array($result)) {
array_push($name_array, $row['name']);
}

return $name_array;

} ?>

2 个答案:

答案 0 :(得分:0)

如果您使用此脚本8次,则将整个内容放入函数中并调用该函数8次而不是复制粘贴。

答案 1 :(得分:0)

在afile.php中放入getNames函数,并在开始时包含一次。从当前文件中取出getNames函数。

所以事情就像这样

在第一个php文件中(比如说)你有这个代码 - filea.php

 function get_names($pool_result)
 {
 $name_array = array();

$query = "SELECT * FROM comments WHERE commentid % 2 = $pool_result";
$result = mysql_query($query);

while ($row = mysql_fetch_array($result)) {
array_push($name_array, $row['name']);
 }

return $name_array;

}

你的第二个文件将有 fileb.php

 $db = mysql_connect('localhost', 'username', 'pass') or die("Database error");
 ..... rest of source code excluded. Make sure you get rid of getNames in this file

现在只按正常情况加入

include 'filea.php'; // include it once only


include 'fileb.php'; // as many times as your wish

或者只是将代码包装在一个函数中并调用它