0

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

这意味着我的 $_POST 数据总是不同的。我需要提取 post 数组,将其剥离并创建一个查询。

这是 Posted 数组的 print_r:

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

正如你所看到的,这个用户标识、modid 和 fid 分为三个部分。问题是,我可以传递我需要的 id 的唯一方法是命名这些字段。所以每个 modid 和 fid 都是 db 中的行。后面的数字是需要更新的id,当然“on”来自复选框。

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

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

对于 modid1:更新表 SET var = var WHERE modid = 1

对于 fid1 更新表 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>

我知道这是一团糟,我正在学习。如果有人能理解我的问题并指出我正确的方向来完成我正在尝试的事情,我将不胜感激。

4

1 回答 1

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 值放在表单中的某个位置(可能作为另一个隐藏字段),以便您拥有处理更新的值。

于 2013-10-28T10:36:10.743 回答