如何从动态数组中提取变量并创建更新查询?

时间:2013-10-28 06:01:24

标签: php mysql arrays dynamic

我有一个基于多个mysql表动态创建的表单。此表单发送到外部页面进行处理。

这意味着我的$ _POST数据将始终不同。我需要提取post数组,将其删除并创建一个查询。

这是已发布数组的print_r:

Array ( [userid] => 1 [modid1] => on [fid1] => on [fid3] => on [fid5] => on [fid7] => on [fid8] => on [modid3] => on )

正如您所看到的,我对此userid,modid和fid有三个部分。问题是,我能够传递id的唯一方法是命名那些字段。所以每个modid和fid都是db中的行。之后的数字是需要更新的ID,当然“on”来自复选框。

所以最终结果会是这样的:

更好地了解我将如何正常编写查询

对于modid1: UPDATE表SET var = var WHERE modid = 1

表示fid1 UPDATE表SET var = var WHERE fid = 1

继承了生成此数组的代码:

<form id="ajaxsubmit" method="post" action="modules/users/updaterights.php">
<?php
$modsql = mysql_query("SELECT * FROM modules")or die("Mod failed " .mysql_error());
while($row = mysql_fetch_array($modsql))
{
echo '<div class="rights">';
echo "<ul>";
$userid = safe($_POST['user']);
$id = $row['id'];
$sql = mysql_query("SELECT * FROM modpermissions WHERE userid = '$userid' AND modid =     '$id'")or die("Mod died " .mysql_error());
$sql2 = mysql_fetch_array($sql);
$modper = $sql2['modpermission'];
    if($modper == 1){
        echo '<li><input type="checkbox" name="modid'.$row["id"].'" checked>&nbsp;  <b>'.$row["name"].'</b></li>';
    }
    if($modper == 0){
        echo '<li><input type="checkbox" name="modid'.$row["id"].'">&nbsp;<b>'.$row["name"].'</b></li>';
    }
if($row['features'] == 1)
{
    echo "<ul>";
    $sql = mysql_query("SELECT * FROM features WHERE modid = '$id'")or die("Features  loop failed " .mysql_error());
    while($row2 = mysql_fetch_array($sql))
    {
        $userid2 = safe($_POST['user']);
        $id2 = $row2['id'];
        $sql3 = mysql_query("SELECT * FROM fpermissions WHERE userid = '$userid2' AND  fid = '$id2'")or die("features died " .mysql_error());
        $sql4 = mysql_fetch_array($sql3);
        $fper = $sql4['fpermission'];
            if($fper == 1){
                echo '<li><input type="checkbox" name="fid'.$row2["id"].'"  checked>&nbsp;'.$row2['feature'].'</li>';
            }
            if($fper == 0){
                echo '<li><input type="checkbox"  name="fid'.$row2["id"].'">&nbsp;'.$row2['feature'].'</li>';
            }
    }
    echo "</ul>";
}
echo "</ul>";
echo '</div>';
}
?>
<p><input type="submit" id="submit" value="Submit" class="button"> <input type="reset"  class="reset" value="Reset Form"> </p>
</form>
我知道,这是一团糟,即时学习。如果有人能够理解我的问题,并指出我正确的方向来完成我想要的事情,我将不胜感激。

1 个答案:

答案 0 :(得分:0)

要做的第一件事是存储旧值以及使用复选框(使用隐藏字段)。

我还建议至少在字段名称中使用固定字符作为分隔符,这样您就可以爆炸字段名称以轻松获取id的部分。

还要考虑使用连接而不是循环一个结果,并为每个结果执行另一个查询。

您的输出脚本如下所示: -

<form id="ajaxsubmit" method="post" action="modules/users/updaterights.php">
<?php
$userid = safe($_POST['user']);
$modsql = mysql_query("SELECT modules.id, modules.features, modules.name, modpermissions.modpermission 
                        FROM modules
                        LEFT OUTER JOIN modpermissions
                        ON modules.id = modpermissions.modid
                        AND modpermissions.userid = '$userid'")or die("Mod failed " .mysql_error());
$PrevModuleId = 0;
while($row = mysql_fetch_array($modsql))
{
    if ($PrevModuleId != $row['id'])
    {
        if ($PrevModuleId != 0)
        {
            echo "</ul>";
            echo '</div>';
        }
        echo '<div class="rights">';
        echo "<ul>";
        $PrevModuleId = $row['id'];
    }
    echo '<li><input type="checkbox" name="modid_'.$row["id"].'" '.(($row['modpermission'] == 1) ? "checked='checked'" : "").'><input type="hidden" name="modid_old_'.$row["id"].'" value="'.$row['modpermission'].'">&nbsp;  <b>'.$row["name"].'</b></li>';
    if($row['features'] == 1)
    {
        echo "<ul>";
        $sql = mysql_query("SELECT features.id, features.feature, fpermissions.fpermission 
                            FROM features 
                            INNER JOIN fpermissions 
                            ON features.id = fpermissions.fid
                            AND fpermissions.userid = $userid
                            WHERE modid = '$id'")or die("Features  loop failed " .mysql_error());
        while($row2 = mysql_fetch_array($sql))
        {
            echo '<li><input type="checkbox" name="fid_'.$row2["id"].'"  '.(($row2['fpermission'] == 1) ? "checked='checked'" : "").'><input type="hidden" name="fid_old_'.$row2["id"].'"  value="'.$row2['fpermission'].'">&nbsp;'.$row2['feature'].'</li>';
        }
        echo "</ul>";
    }
}
if ($PrevModuleId != 0)
{
    echo "</ul>";
    echo '</div>';
}
?>
<p><input type="submit" id="submit" value="Submit" class="button"> <input type="reset"  class="reset" value="Reset Form"> </p>
</form>

然后,您可以遍历$ _POST数组中的每个条目,根据_字符展开键,检查值何时更改以及是否需要进行更新或者可能使用INSERT,但使用ON DUPLICATE KEY更新类型语法(这样您可以轻松更新多个具有不同值的行)。

请注意,您还需要将userid值放在表单中的某个位置(可能是另一个隐藏字段),这样您就有了处理更新的值。