PHPで My SQLにinsertするには table はどこで指定すればいいですか?
<?php header("Content-type: text/html; charset=utf-8"); if(empty($_POST)) { header("Location: input2.html"); exit(); }else{ //名前入力判定 if (!isset($_POST['yourname']) || $_POST['yourname'] === "" ){ $errors['name'] = "名前が入力されていません。"; } } if(count($errors) === 0){ $dsn = 'mysql:host=localhost;dbname=test3;charset=utf8'; $user = 'root'; $password = 'root'; try{ $dbh = new PDO($dsn, $user, $password); $statement = $dbh->prepare("INSERT INTO name (name) VALUES (:name)"); if($statement){ $yourname = $_POST['yourname']; //プレースホルダへ実際の値を設定する $statement->bindValue(':name', $yourname, PDO::PARAM_STR); if(!$statement->execute()){ $errors['error'] = "登録失敗しました。"; } //データベース接続切断 $dbh = null; } }catch (PDOException $e){ print('Error:'.$e->getMessage()); $errors['error'] = "データベース接続失敗しました。"; } } ?> <!DOCTYPE html> <html> <head> <title>登録画面</title> <meta charset="utf-8"> </head> <body></html><?php if (count($errors) === 0): ?> <p><?=htmlspecialchars($yourname, ENT_QUOTES, 'UTF-8')."さんで登録いたしました。"?></p> <?php elseif(count($errors) > 0): ?> <?php foreach($errors as $value){ echo "<p>".$value."</p>"; } ?> <?php endif; ?> </body>
質問は編集できます。
コードやエラーはマークダウンのcode機能を利用してご提示ください。
https://teratail.com/questions/238564
マークダウンで提示されてないと、読みにくくて仕方ないです。
マークダウン対応されてないだけで質問読まない回答者も少なからずいます。
インデントなども反映されていないし、1クリックでコピペもできないので、見ている人にやさしくないからです。
あと、既に「name」というテーブルを指定してINSERT文書かれてます。
テーブル定義どうなってますか?
「CREATE TABLE文」でご提示ください(調べてください)
何度やってもできません
$statement = $dbh->prepare("INSERT INTO name (name) VALUES (:name)");
の(name)はなにを表していますか?
質問は編集できます。
コードはマークダウンで提示してください(再三指摘しています)
>の(name)はなにを表していますか?
調べても何も出ないのでしょうか。
そもそも何をもとに書いたコードなのでしょうか。
(name)は、列名です。
INSERT INTO テーブル名 (列名) VALUES (列名に対する実データ);
です。
よって、nameというテーブルが必要でそのnameテーブルにnameという列が必要です。
Create Table文でクエリーを発行してテーブルを作成するかMySQLの管理ツールのデザイナーかなんかで作成できるものもあると思いますので事前に作ってください。
あなたの回答
tips
プレビュー