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

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

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

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

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

MAMP

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

Q&A

解決済

1回答

1165閲覧

phpのログイン画面でPDOからtable名が見つからないエラー

KazuhoAkabane

総合スコア56

MySQL

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

PDO

PDO(PHP Data Objects)はPHPのデータベース抽象化レイヤーです。

PHP

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

ログイン

ログインは、ユーザーがコンピューターシステムにアクセスするプロセスの事を呼びます。

MAMP

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

0グッド

0クリップ

投稿2019/09/01 13:29

編集2019/09/01 16:15

前提・実現したいこと

localhostでmysqlをターミナルから入力しているのですが、usersテーブルを作ってphpからPDOから値を取り出そうとすると以下のエラーが出ます。
Array ( [0] => 42S02 [1] => 1146 [2] => Table 'tennis.users' doesn't exist )
Fatal error: Uncaught Error: Call to a member function bindParam() on boolean in /Applications/MAMP/htdocs/login.php:30 Stack trace: #0 {main} thrown in /Applications/MAMP/htdocs/login.php on line 30

結構調べて見たのですが、どうしてもtennis.usersのテーブルだけ繋がらないです。

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

Array ( [0] => 42S02 [1] => 1146 [2] => Table 'tennis.users' doesn't exist )
Fatal error: Uncaught Error: Call to a member function bindParam() on boolean in /Applications/MAMP/htdocs/login.php:30 Stack trace: #0 {main} thrown in /Applications/MAMP/htdocs/login.php on line 30

該当のソースコード

PHP

1<?php 2 session_start(); // セッション開始 3// エラーを出力する 4error_reporting(E_ALL); 5ini_set('display_errors', '1'); 6 7 if (isset($_SESSION['id'])){ 8 // セッションにユーザIDがある=ログインしている 9 // トップページに遷移する 10 header('Location: index.php'); 11 12 } else if (isset($_POST['USERNAME']) && isset($_POST['USERPASS'])){ 13 // ログインしていないがユーザ名とパスワードが送信されたとき 14 15 // データベースに接続 16 $dsn = 'mysql:host=localhost;dbname=tennis;charset=utf8'; 17 $user = 'tennisuser'; 18 $password = 'password'; // tennisuserに設定したパスワード 19 20 try { 21 $db = new PDO($dsn, $user, $password); 22 $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); 23 // プリペアドステートメントを作成 24 $stmt = $db->prepare( 25 "SELECT * FROM tennis.users WHERE USERNAME=:name AND USERPASS=:pass" 26 ); 27 print_r($db->errorInfo()); 28 29 // パラメータを割り当て 30 $stmt->bindParam(':name', $_POST['USERNAME'], PDO::PARAM_STR); 31 $stmt->bindParam(':pass', sha1($_POST['USERPASS']), PDO::PARAM_STR); 32 33 //クエリの実行 34 $stmt->execute(); 35 36 if ($row = $stmt->fetch()){ 37 // ユーザが存在していたので、セッションにユーザIDをセット 38 $_SESSION['id'] = $row['id']; 39 header('Location: index.php'); 40 exit(); 41 } else { 42 // 1レコードも取得できなかったとき 43 // ユーザ名・パスワードが間違っている可能性あり 44 // もう一度ログインフォームを表示 45 header('Location: login.php'); 46 exit(); 47 } 48 } catch(PDOException $e){ 49 die('エラー:' . $e->getMessage()); 50 } 51 52 } else { 53 // ログインしていない場合はログインフォームを表示する 54?> 55 56<html> 57<head> 58 <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> 59 <title>テニスサークル交流サイト</title> 60</head> 61<body> 62 <h1>テニスサークル交流サイト</h1> 63 64 <h2>ログイン</h2> 65 <form action="login.php" method="post"> 66 <p>ユーザ名:<input type="text" name="USERNAME"></p> 67 <p>パスワード:<input type="password" name="USERPASS"></p> 68 <p><input type="submit" value="ログイン"></p> 69 </form> 70 71</body> 72</html> 73<?php } ?> 74 75```MYSQL 76mysql> show tables; 77+------------------+ 78| Tables_in_tennis | 79+------------------+ 80| bbs | 81| users | 82+------------------+ 832 rows in set (0.00 sec) 84 85mysql> SELECT * FROM users; 86+----+----------+------------------------------------------+ 87| id | USERNAME | USERPASS | 88+----+----------+------------------------------------------+ 89| 1 | yamada | ad5a93cf64f180873ccec48d02bf1439c0d9681c | 90| 2 | tanaka | 4f01ddd22aef5103bd2676e38babb1fbfa2b6b33 | 91| 3 | kikuchi | 30c95868d550d9d41c77aa0bb65c8f6c8277a1f8 | 92+----+----------+------------------------------------------+ 933 rows in set (0.01 sec) 94 95 96### 試したこと 97 98usersテーブルの箇所を他のtable名に変えると接続ができる。 99このusersのテーブルだと繋がりません。 100 101### 補足情報(FW/ツールのバージョンなど) 102 103PHP初心者です。localhost/login.php自体は表示できるのですが、IDとパスワードを入力して送信するとこのようのな画面になります。

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

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

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

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

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

guest

回答1

0

自己解決

phpMyadminで確認したところ、usersのtable自体が作成されてませんでした。ターミナルでは見れていたのですがこちらに反映されていないみたいなのでこちらから入力したらできました。

投稿2019/09/01 16:54

KazuhoAkabane

総合スコア56

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問