0

这似乎应该是一个简单的,但我已经搜索过,似乎无法弄清楚。我正在使用 PHP 更新 MySQL 数据库,该数据库将一些字段设置为布尔开关。网站上的触发器是一个复选框。当用户选中该框时,该值设置为 1,未选中时,该值为零。问题是,当我发送表单时,设置复选框时数据库更新正常,但是它不会将字段的值更新为零,它只是忽略它。我在未设置时回显了该值,以验证该变量是否确实设置为零。当我尝试清除文本框并且什么都不发送时,我发现了类似的问题。MySQL 只是忽略它并且不会清除该字段。我错过了什么吗?

这是我正在使用的代码示例:

<?php
if ($_POST) {   
    if (isset($_POST['box1'])) {
        $box1 = $_POST['box1'];
    }
    else {
        $box1 = 0;
    }
    $query = "UPDATE table SET box1 = '{$box1}'";
    $result = mysqli_query($dbc, $query);
}
    ?>

<form method="post" action="">
    <input type="checkbox" name="box1"> Box 1
</form>
4

2 回答 2

0

<input type="checkbox" name="box1">

应该

<input type="checkbox" name="box1" value="1">

数据库中的数据类型box1应该是INT这样,即使它没有设置为0它仍然会被保存,0因为你根本不能在一个字段中存储任何内容INT作为数据类型。

于 2013-01-10T18:40:37.897 回答
0

目前,如果没有在数组中传递任何值,则不会发生任何操作。

考虑以下...

...
$box1=0;

if ($_POST) {
    if (isset($_POST['box1'])) {
        $box1 = $_POST['box1'];
    }
}
    $query = "UPDATE boxtest SET box1 = $box1";
    $result = mysqli_query($dbc,$query);
    ?>

<form method="post" action=""/>
    <input type="checkbox" name="box1" value="1"/> Box 1
    <input type="submit"/>
</form>

或(根据我之前的评论)

<input type="hidden" name="box1" value="0" />
<input type="checkbox" name="box1" value="1"/>
于 2013-01-10T19:57:25.490 回答