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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

MAMP

Mac 上で WordPress などの動的ページのサイトが作れるように環境を構築するフリーソフト

Q&A

解決済

1回答

2633閲覧

PHPで入力したデータをDBに登録したい

demenigisu

総合スコア5

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

MAMP

Mac 上で WordPress などの動的ページのサイトが作れるように環境を構築するフリーソフト

0グッド

0クリップ

投稿2019/11/16 17:58

編集2019/11/16 23:40

入力したデータをDBに登録したい

入力したデータをDBに登録するために,PDOを使用して実現するサイトを参考にしていたのですが,どれもエラーが出るので,mysqliで実現しているちらのサイトを参考にしてプログラムを書きました.
リンク内容
そのままのソースコードでは1つのデータしかDBに追加できないため,いろいろ調べながら複数のデータをDBに登録するコードを書いたのですがうまく行きません.
DBの情報は以下に示します.

DB名 vote
テーブル名 vote_db

+-------+--------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+--------------+------+-----+---------+----------------+ | id | int(50) | NO | PRI | NULL | auto_increment | | name | varchar(100) | YES | | NULL | | | vote | int(100) | YES | | NULL | | +-------+--------------+------+-----+---------+----------------+

PHPもMYSQLも初心者です.よろしくお願いいたします.

発生している問題・エラーメッセージ

2031No data supplied for parameters in prepared statement

該当のソースコード

php

1<?php 2 3header("Content-type: text/html; charset=utf-8"); 4 5//データベース接続 6$server = "localhost"; 7$userName = "root"; 8$password = "root"; 9$dbName = "vote"; 10 11$mysqli = new mysqli($server, $userName, $password,$dbName); 12 13if ($mysqli->connect_error){ 14 echo $mysqli->connect_error; 15 exit(); 16}else{ 17 $mysqli->set_charset("utf-8"); 18} 19 20if(empty($_POST)) { 21 echo "<a href='test.php'>test.php</a>←こちらのページからどうぞ"; 22}else{ 23 //入力判定 24 if (!isset($_POST['name']) || $_POST['name'] === "" ){ 25 echo "nameが入力されていません。"; 26 }else if(!isset($_POST['vote']) || $_POST['vote'] === "" ){ 27 echo "voteが入力されていません。"; 28 }else{ 29 //プリペアドステートメント 30 $stmt = $mysqli->prepare("INSERT INTO vote_db(name,vote) VALUES (?,?)"); 31 32 if($stmt){ 33 //プレースホルダへ実際の値を設定する 34 $stmt->bind_param('s', $name); 35 $stmt->bind_param('s', $vote); 36 37 $name = $_POST['name']; 38 $vote = $_POST['vote']; 39 40 if($stmt->execute()){ 41 echo htmlspecialchars($name, ENT_QUOTES, 'UTF-8').",".htmlspecialchars($vote, ENT_QUOTES, 'UTF-8')."を登録いたしました。"; 42 }else{ 43 echo $stmt->errno . $stmt->error; 44 } 45 46 //ステートメント切断 47 $stmt->close(); 48 }else{ 49 echo $mysqli->errno . $mysqli->error; 50 } 51 } 52} 53 54// データベース切断 55$mysqli->close(); 56 57?>

補足情報(FW/ツールのバージョンなど)

OS Mac10.15
PHP 7.3.8
MYSQL 5.7.26
MAMP 5.4

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

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

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

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

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

guest

回答1

0

ベストアンサー

下記、逆だと思います。

php

1 $stmt->bind_param('s', $name); 2 $stmt->bind_param('s', $vote); 3 4 $name = $_POST['name']; 5 $vote = $_POST['vote'];

php

1 $name = $_POST['name']; 2 $vote = $_POST['vote']; 3 4 $stmt->bind_param('s', $name); 5 $stmt->bind_param('s', $vote);

定義・代入が先です。
エラーも

No data supplied for parameters in prepared statement

準備済みステートメントのパラメーターにデータが提供されていません

とあります。
エラーメッセージの読み方と対処, 検索や質問の原則

それにエラー表示はONにしておいた方が良いです。
元のコードだと変数未定義のエラーが出ているはずです。

あとできればmysqliよりPDOのほうが諸々使いやすいと思います。
PHPでデータベースに接続するときのまとめ

どれもエラーが出るので,

そのエラーを追及された方が良いでしょう(結局mysqliでもエラー出てるので)

投稿2019/11/16 21:56

編集2019/11/16 21:59
m.ts10806

総合スコア80850

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問