こちらの問題なのですが、自分でエラーを修正することができ、問題を解決することができました。
単純なテーブル名のミスでした。。。
お騒がせしました。
一言掲示板にて、利用者の過去の発言内容をデータベースに格納し表示するプログラムを作っているのですが、エラーが出てしまってうまくいきません...
実際に自分が作成したコードはこちらです。
PHP
1<?php 2date_default_timezone_set('Asia/Tokyo'); 3$date = date("Y-m-d H:i:s"); 4$errors = array(); 5$host = 'localhost'; 6$db_username = 'newyee'; 7$passwd = ''; 8$dbname = 'c9'; 9$link = mysqli_connect($host,$db_username,$passwd,$dbname); 10 11if($link !== FALSE){ 12 mysqli_set_charset($link, 'utf8'); 13 if ($_SERVER['REQUEST_METHOD'] === 'POST') { 14 15 if(isset($_POST['user_name']) === TRUE){ 16 $user_name = trim(mb_convert_kana($_POST['user_name'],"s",'UTF-8')); 17 } 18 19 if(isset($_POST['user_comment']) === TRUE){ 20 $user_comment = trim(mb_convert_kana($_POST['user_comment'],"s",'UTF-8')); 21 } 22 23 if(mb_strlen($user_name) > 20){ 24 $errors[] = '名前は20文字以内で入力してください'; 25 }elseif(mb_strlen($user_name) === 0){ 26 $errors[] = '名前を入力してください'; 27 } 28 if(mb_strlen($user_comment) > 100){ 29 $errors = 'ひとことは100文字以内で入力してください'; 30 }elseif(mb_strlen($user_comment) === 0){ 31 $errors[] = 'ひとことを入力してください'; 32 } 33 } 34 if(empty($errors) === TRUE){ 35 $query = 'INSERT INTO Bulletin_bord(user_name,user_comment,date) 36 VALUES(\'' . $user_name . '\',\'' . $user_comment . '\',\'' . $date . '\')'; 37 $result = mysqli_query($link,$query); 38 if($result === FALSE){ 39 $errors[] = '登録に失敗しました'; 40 } 41 } 42 $data = array(); 43 $query = 'SELECT user_name,user_comment,date FROM Bulletin_bord'; 44 $result = mysqli_query($link,$query); 45 46 while($row = mysqli_fetch_array($result)){ 47 $data[] = $row; 48 } 49 50} 51?> 52<!DOCTYPE html> 53<html lang="ja"> 54<head> 55 <meta charset="UTF-8"> 56 <title></title> 57</head> 58<body> 59 <h1>一言掲示板</h1> 60 <form method="post"> 61 <p>名前 : 62 <input type="text" name="user_name"> 63 ひとこと : 64 <input type="text" name="user_comment"> 65 <input type="submit" value="送信"> 66 </p> 67 </form> 68 <?php foreach ($errors as $value){ ?> 69 <p><?php echo htmlspecialchars($value, ENT_QUOTES, 'UTF-8'); ?></p> 70 <?php } ?> 71 72 <ul> 73 <?php foreach ($data as $value) { ?> 74 <li> 75 <?php echo htmlspecialchars($value['user_name'],ENT_QUOTES,'UTF-8'); ?> 76 <?php echo htmlspecialchars($value['user_comment'],ENT_QUOTES,'UTF-8'); ?> 77 <?php echo htmlspecialchars($value['date'],ENT_QUOTES,'UTF-8'); ?> 78 </li> 79 <?php } ?> 80 </ul> 81</body> 82</html> 83 84
データベースはphpmyadminを使っております。
以下の画像は実際に自分が作成した、テーブルになります。
テーブル名はBulletin_bordです。
エラーの内容は以下の通りです。
Warning: mysqli_fetch_array() expects parameter 1 to be mysqli_result, boolean given in /home/ubuntu/workspace/review/lesson16/practice_bbs_db_intermediate.php on line 46 Call Stack: 0.0032 236672 1. {main}() /home/ubuntu/workspace/review/lesson16/practice_bbs_db_intermediate.php:0 0.0168 246696 2. mysqli_fetch_array() /home/ubuntu/workspace/review/lesson16/practice_bbs_db_intermediate.php:46
どなたか分かる方いましたら、ご教授願います...
回答1件
あなたの回答
tips
プレビュー