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

Php 将表单中的数据输入数据库PDO,php,mysql,forms,pdo,Php,Mysql,Forms,Pdo,我学习了MySQL,创建了一个表单,并让它与数据库一起工作。然后有人告诉我应该用准备好的语句进行PDO,所以我对此做了一些研究并修改了代码 我现在有了正确的代码(我想),但我不知道数据是如何输入的。正如您在我的代码中看到的,我让数据库在用户提交表单时创建行。但是,数据库只会在//插入一行和//插入另一行下的语音标记内拾取任何内容 例如,现在如果用户完成并提交表单,无论他们输入什么信息,我只会得到“Joe”和“Joe”joe@example.com'等显示在我的数据库中。显然,我需要他们的答案,否

我学习了MySQL,创建了一个表单,并让它与数据库一起工作。然后有人告诉我应该用准备好的语句进行PDO,所以我对此做了一些研究并修改了代码

我现在有了正确的代码(我想),但我不知道数据是如何输入的。正如您在我的代码中看到的,我让数据库在用户提交表单时创建行。但是,数据库只会在
//插入一行
//插入另一行
下的语音标记内拾取任何内容

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

表格:

更改此项—

// 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属性访问它们。

将用户输入的数据发布到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>

这是因为您没有使用
$\u POST
数组中的信息更新变量。例如
$stu\u name=$\u POST[stu\u name']
如果表单的输入
name=“stu\u name”
,我真的看不出你的目标是什么。请向我们展示你的全部代码以及你希望得到什么结果?现在你已经发布了你的表单,请阅读我的第一条评论。我也用我的html表单更新了我的问题。用户填写表单,然后将信息发送到数据库。这就是我的目标。
$stu_name=“Joe”你期望什么?php会自动更改这些硬编码的东西吗?谢谢!!这很有效。非常感谢你的帮助;非常新。@user2132851供参考:(如果您有一个带有get方法的表单,您可以使用
$\u get
访问它,如果它是post方法,它是
$\u post
;只需执行
打印($\u post);
即可查看数组的结构)谢谢!一切都变得更加清晰了。我比较擅长HTML和CSS,但PHP和数据库是一个全新的世界!
// insert a row
$stu_name = $_POST['stu_name'];
$stu_email = $_POST['stu_email'];
$stu_city = $_POST['stu_city'];
$stmt->execute();
<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>
   //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;
}