質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

0回答

435閲覧

My SQLのカラムにinsertしたい

mimi3

総合スコア1

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2020/09/30 09:47

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>
<?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>
</html>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/09/30 09:50 編集

質問は編集できます。 コードやエラーはマークダウンのcode機能を利用してご提示ください。 https://teratail.com/questions/238564 マークダウンで提示されてないと、読みにくくて仕方ないです。 マークダウン対応されてないだけで質問読まない回答者も少なからずいます。 インデントなども反映されていないし、1クリックでコピペもできないので、見ている人にやさしくないからです。 あと、既に「name」というテーブルを指定してINSERT文書かれてます。 テーブル定義どうなってますか? 「CREATE TABLE文」でご提示ください(調べてください)
mimi3

2020/09/30 10:31

何度やってもできません
mimi3

2020/09/30 10:32 編集

$statement = $dbh->prepare("INSERT INTO name (name) VALUES (:name)"); の(name)はなにを表していますか?
m.ts10806

2020/09/30 11:12 編集

質問は編集できます。 コードはマークダウンで提示してください(再三指摘しています) >の(name)はなにを表していますか? 調べても何も出ないのでしょうか。 そもそも何をもとに書いたコードなのでしょうか。
shinami

2020/10/17 11:31 編集

(name)は、列名です。 INSERT INTO テーブル名 (列名) VALUES (列名に対する実データ); です。 よって、nameというテーブルが必要でそのnameテーブルにnameという列が必要です。 Create Table文でクエリーを発行してテーブルを作成するかMySQLの管理ツールのデザイナーかなんかで作成できるものもあると思いますので事前に作ってください。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問