将表单中的数据输入数据库 PDO

Posted

技术标签:

【中文标题】将表单中的数据输入数据库 PDO【英文标题】:Entering data from form into Database PDO 【发布时间】:2015-04-22 18:04:48 【问题描述】:

我学习了 mysql,创建了一个表单并让它与数据库一起使用。然后我被告知我应该使用准备好的语句来执行 PDO,所以我对此进行了一些研究并更改了我的代码。

我现在的代码是正确的(我认为),但我无法弄清楚数据是如何输入的。正如您在我的代码中看到的那样,我让数据库在用户提交表单时创建行。然而,数据库只会获取//insert a row//insert another row 下的语音标记内的任何内容。

例如,现在如果用户完成并提交表单,无论他们输入什么信息,我的数据库中都会显示“Joe”和“joe@example.com”等。显然我需要他们的答案,否则我的表格将是无关紧要的(数据提交也是如此)。我完全错过了标记还是我错过了一些愚蠢的东西?我试过改变和研究,但我很挣扎。对这一切真的很陌生。

表格:

<form action="testsubmit-pdo.php" method="post">
<label>Student Name :</label>
<input type="text" name="stu_name" id="name" required="required"       placeholder="Please Enter Name"/><br /><br />
<label>Student Email :</label>
<input type="email" name="stu_email" id="email" required="required" placeholder="john123@gmail.com"/><br/><br />
<label>Student City :</label>
<input type="text" name="stu_city" id="city" required="required" placeholder="Please Enter Your City"/><br/><br />
<input type="submit" value=" Submit " name="submit"/><br />
</form>

PHP:

try 
$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);

// set the PDO error mode to exception
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

// prepare sql and bind parameters
$stmt = $conn->prepare("INSERT INTO demo (stu_name, stu_email, stu_city)
VALUES (:stu_name, :stu_email, :stu_city)");
$stmt->bindParam(':stu_name', $stu_name);
$stmt->bindParam(':stu_email', $stu_email);
$stmt->bindParam(':stu_city', $stu_city);

// insert a row
$stu_name = "Joe";
$stu_email = "joe@example.com";
$stu_city = "Joeland";
$stmt->execute();

// insert another row
$stu_name = "Mary";
$stu_email = "mary@example.com";
$stu_city = "Maryland";
$stmt->execute();

echo "New records created successfully";

catch(PDOException $e)

echo "Error: " . $e->getMessage();

$conn = null;

【问题讨论】:

这是因为您没有使用 $_POST 数组中的信息更新变量。例如$stu_name = $_POST[stu_name'],如果表单的输入name="stu_name" 我真的不明白你的目标是什么。请向我们展示您的整个代码以及您期望的结果? 既然您已经发布了表单,请阅读我的第一条评论。 我也用我的 html 表单更新了我的问题。用户填写表格,该信息被发送到数据库。这就是我的目标。 $stu_name = "Joe"; 你期待什么?那个 php 会自动更改这些硬编码的东西? 【参考方案1】:

改变这个 -

// insert a row
$stu_name = "Joe";
$stu_email = "joe@example.com";
$stu_city = "Joeland";
$stmt->execute();

// insert another row
$stu_name = "Mary";
$stu_email = "mary@example.com";
$stu_city = "Maryland";
$stmt->execute();

到这里-

// insert a row
$stu_name = $_POST['stu_name'];
$stu_email = $_POST['stu_email'];
$stu_city = $_POST['stu_city'];
$stmt->execute();

您的表单会将值放在 PHP 的 POST 数组中,您可以通过表单中的 name 属性访问它们。

【讨论】:

谢谢!!这非常有效。非常感谢您的所有帮助;对此非常陌生。 @user2132851 仅供参考:php.net/manual/en/reserved.variables.post.php(如果您有一个带有 get 方法的表单,您可以使用 $_GET 访问它,如果它是 post 方法,它是 $_POST;只需执行 print_r($_POST); 即可查看数组结构) 谢谢!一切都变得更加清晰了。我比较擅长 HTML 和 CSS,但是 PHP 和数据库是一个全新的世界!【参考方案2】:

您将用户输入的数据发布到您的 php 文件中

<form action="some_php_file.php" method="post">
  <input type="text" name="stu_name">
   <input type="email" name="stu_email">
  <input type="text" name="stu_city">
  <input type="submit" name="submit" value="submit">
</form>

在php代码中,首先需要检查提交按钮是否被点击

   //check if submit button is clicked
  If(isset($_POST['submit']))
    try 
    $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);

  // set the PDO error mode to exception
   $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

   // prepare sql and bind parameters
   $stmt = $conn->prepare("INSERT INTO demo (stu_name, stu_email, stu_city)
    VALUES (:stu_name, :stu_email, :stu_city)");
    $stmt->bindParam(':stu_name', $stu_name);
   $stmt->bindParam(':stu_email', $stu_email);
   $stmt->bindParam(':stu_city', $stu_city);

    $stu_name = $_POST['stu_name'];
    $stu_email = $_POST['stu_email'];
    $stu_city = $_POST['stu_city'];
    $stmt->execute();
    echo "New records created successfully";
catch(PDOException $e)
  echo "Error: " . $e->getMessage();

$conn = null;

【讨论】:

以上是关于将表单中的数据输入数据库 PDO的主要内容,如果未能解决你的问题,请参考以下文章

单击添加新按钮并使用php-pdo将数据插入数据库时​​如何生成2个新输入字段[关闭]

使用 PDO 从 php 页面将具有更多列的表单数据插入 mysql 数据库

如何使用准备好的语句将表单数据插入 PDO?

JS数组到PHP并使用PDO更新MYSQL中的表

如何将出生日期从数据库显示到表单并在 php 和 PDO 中更新?

更新选择列表而不刷新 [PDO/PHP/AJAX]