我正在处理用户进行一些选择的表单,然后每个所选项目的名称需要进入数据库中的表。用户的名称可以与每个项目一起作为用户选择的标识符。选择的数量和选择的名称将更改,但数据库中的两个字段保持不变。我的问题是在插入时,我得到一个错误,即没有列我在发送的VALUE中指定了名称。它绊倒了我......无法弄明白为什么。非常感谢任何帮助或建议。
完整代码:
<?php
$db = mysql_connect('localhost', 'root', 'root') or die(mysql_error());
mysql_select_db('reflex') or die(mysql_error());
$name_array = array('harp1','harp2','harp3');
if (isset($_POST['interests'])) {
$interests_str = implode(" ", $_POST['interests']);// converts $_POST interests into a string
$interests_array = explode(" ", $interests_str);// converts the string to an array which you can easily manipulate
foreach ($name_array as $row=>$name)
{
$username = mysql_real_escape_string($name);
$photo = mysql_real_escape_string($_POST['interests'][$row]);
mysql_query('INSERT INTO photos (username, photo) VALUES ("' . $username . '", ' . $photo . ')') or die(mysql_error());
}
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>array test</title>
</head>
<body>
<form action="array.php" method="post">
<input type="checkbox" name="interests[]" value="Politics" />Politics<br />
<input type="checkbox" name="interests[]" value="Entertainment" /><br />
<input type="checkbox" name="interests[]" value="Tech" /><br />
<input type="checkbox" name="interests[]" value="Health" /><br />
<input type="checkbox" name="interests[]" value="Living" /><br />
<input type="checkbox" name="interests[]" value="Travel" /><br />
<input type="checkbox" name="interests[]" value="World" /><br />
<input type="submit" value="Submit">
</form>
</body>
</html>
答案 0 :(得分:0)
$ photo不会被SQL语句中的引号包围。此外,循环如下:
循环1:$ username =“harp1”,$ photo =“[首选复选框的值]”
循环2:$ username =“harp2”,$ photo =“[second value]”
循环3:$ username =“harp3”,$ photo =“[第三个值]”
它没有意义......
答案 1 :(得分:0)
使用双引号字符串创建数据库查询:
mysql_query("INSERT INTO photos (username, photo) VALUES ('$username', '$photo')")
or die(mysql_error());
你忘了在$photo
附近加上引号。双引号字符串通过使它们更易于阅读来减少此类错误。