前提・実現したいこと
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とパスワードを入力して送信するとこのようのな画面になります。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。