如何将简单数组插入数据库(php / MySQL)?

时间:2011-02-06 07:47:25

标签: php

我正在处理用户进行一些选择的表单,然后每个所选项目的名称需要进入数据库中的表。用户的名称可以与每个项目一起作为用户选择的标识符。选择的数量和选择的名称将更改,但数据库中的两个字段保持不变。我的问题是在插入时,我得到一个错误,即没有列我在发送的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>

2 个答案:

答案 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附近加上引号。双引号字符串通过使它们更易于阅读来减少此类错误。