Add -6ren">
gpt4 book ai didi

php - 使用 "foreach"将多个单选按钮值发布到 MySQL

转载 作者:行者123 更新时间:2023-11-29 15:01:22 24 4
gpt4 key购买 nike

我稍微调整了我的代码,但我仍然很难将其发布到表中。有人可以给我提供一个 foreach 数组的示例吗?

表单页面

  <div style="padding: 15px;">

<span class="loginfail" style="font-size:24px; font-weight: bold">Notifications</span><p>

<?php include("progress_insertcomment.php"); ?>

<?php

// Make a MySQL Connection
mysql_select_db("speedycm_data") or die(mysql_error());

$query_comment = "select * from tbl_alert order by id desc limit 1";
$comment = mysql_query($query_comment, $speedycms) or die(mysql_error());
$row_comment = mysql_fetch_assoc($comment);
$totalRows_comment = mysql_num_rows($comment);

?>

<!--- add notification --->

<form method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">
<span id="sprytextarea1">

<textarea id='comment' name="comment" style="height: 75px; width:330px;"><?php echo $row_comment['comment']; ?></textarea>
</span>
<p>
<button type="submit">Add</button>
<input type="hidden" name="notc" value="1"/>
</form>

<!--- notification history --->

<form method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">

<table border="0" cellspacing="2" cellpadding="2">
<?php

if ( $row_comment == 0 ) {

echo "<span style='font-size: 11px;'>No current alerts.</span>";

} else {

// Get all the data from the "example" table
$result = mysql_query("SELECT * FROM tbl_alert ORDER BY id DESC")
or die(mysql_error());

while($rows=mysql_fetch_array($result)){ ?>
<tr>
<td>
<?php
echo "<div class='bubble'><div class='pimped'>
<blockquote>" . $rows['comment'] . "
</blockquote></div>
<cite><strong>" . $rows['user'] . "</strong> @ " . $rows['date'] . "</cite>
<span style='font-size: 10px;'>
<p>
<a href='editalert.php?id=". $rows['id'] ."' class='form' >Edit</a>&nbsp;&#8226;&nbsp;<a href='deletealert.php?id=". $rows['id'] ."' class='form'>Delete</a>
</span>
</div>
";
?>
</td>
<td valign="top" align="center"><div style="padding-left: 30px;"><span style="font-size: 10px;">Completed?</span>
<p class="field switch">

<!--- determine status of notification --->

<?php $status = $rows['status']; ?>

<input type="radio" name="selstatus" value="no" <?php if($status == 'yes') {echo 'checked';} else {echo '';} ?>/>
<input type="radio" name="selstatus" value="yes" <?php if($status == 'yes') {echo 'checked';} else {echo '';} ?>/>
<input type="hidden" name="statusid" value="<?php echo $rows['id']; ?>"/>
<label for="radio1" class="cb-enable <?php if($status == 'yes') {echo 'selected';} else {echo '';} ?>"><span>Yes</span></label>
<label for="radio2" class="cb-disable <?php if($status == 'no') {echo 'selected';} else {echo '';} ?>"><span>No</span></label>
</p>
</div></td>
</tr>
<tr>
<td></td>
<?php
}
}
?>
<td align="center"><div style="padding-left: 30px;">
<button type="submit">Update</button>
<input type="hidden" name="notc2" value="1"/>
</div></td>
</tr>
</table>
</form>

</div>
</body>

正在处理

           <?php   

// 6) update notifications

if (array_key_exists('notc2',$_POST)) {

echo "<p style='font-size: 12px;'>Thank you. The notifications have been updated successfully.<p>";

echo "<p><span style='font-size: 12px;'>
<a onClick=\"history.go(-1)\" class='form'>Return</a></p>
<p></span>
";

exit;

};
?>

经过一些研究,我了解到将多个单选值插入 MySQL 表的唯一方法是使用数组。该网站上的某个地方提出了类似的问题:PHP multiple radio buttons建议使用 foreach 循环。

使用foreach循环

<?php
foreach ( $_POST as $key => $val )
echo "$key -> $val\n";
?>

$key 将是所选选项的名称,$val 是值。

这如何适用于我的情况? - 我正在努力在互联网上寻找任何帮助。我知道我会在处理页面上使用它来从上一页中提取任何单选值,然后在进程中循环 INSERT MySQL 代码,直到全部完成。

最佳答案

据我所知,这些是多行。要让 PHP 以一种节省大量时间的方式解析 POST,我建议您阅读以下内容:http://nl2.php.net/manual/en/language.variables.external.php

如果您的表tbl_alert有某种id,您可以使用向单选按钮添加名称,如下所示:

 <input type="radio" name="selstatus[<?phpecho $row['id'];?>]" ....

...这将在 $_POST['selstatus'] 中为您提供一个很好的可循环数组,其中警报的 id 作为键,单选按钮的值作为值。尝试使用 print_rvar_dump $_POST 来查看差异。对于每个条目,您可以根据需要运行 UPDATE 或 INSERT 查询。

关于php - 使用 "foreach"将多个单选按钮值发布到 MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3002690/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com