同じ質問が数多くあるようですが、どうにもうまくいかない為恐縮ですが質問させて頂きました。
私はPHPとMYSQLを使ってホームページを作成しております。
やりたいことは、DBのTBに数百ある情報をPHPで幾つかの条件で絞り込み検索をかけることで、それ自体はできたのですが、何件の結果が抽出されたかを表示することができません。
例:○○件の検索結果が表示されました。 ←こんな感じにしたいのです。
他の質問を参考に以下のように記述をしたのですがどうにもうまくいきません。
$sql ="SELECT*FROM estate WHERE 価格 BETWEEN $price1 AND $price2'";
print 'sql_num_fields( $sql ) . "\n"件の検索結果が表示されました';
どのような点が問題なのか教えていただけますでしょうか?
できればソースを教えていただけると助かります。
No.10ベストアンサー
- 回答日時:
以下簡素化したPDOサンプルです。
今のコードに合わせてカスタマイズしてみてください。
<?php
#以下データベース名、ユーザー名、パスワードをセット
$dbname='';
$username='';
$password='';
#PDOのデータベースオブジェクト作成
$db = new PDO("mysql:host=localhost;dbname=".$dbname,$username,$password);
#$dbを使って結果セット取得
$sql="SELECT * FROM estate WHERE 価格 BETWEEN $price1 AND $price2 AND 駅距離1 BETWEEN $minute1 AND $minute2 AND 市区町村 ='$area1'";
$res=$db->query($sql);
$rows=$res->fetchAll(PDO::FETCH_ASSOC);
#結果セットを使ってリスト出力
foreach($rows as $r){
echo $r['施設名'].' '.$r['価格'].' '.$r['交通'].' '.$r['所在地']."<br />\n";
}
#合計件数出力
echo '<br />合計'.$res->rowCount().'件です';
ありがとうございます!
ようやく待ちに待った結果が出てきました!
感無量です。
長い間おつきあい頂き本当にありがとうございます。
No.8
- 回答日時:
最近の書籍でしたら、今メジャーなPDOを使ってると想定しまして、
PDOはrowCount()で件数取得します。
結果セット取得コマンド
$res = $db->query('SELECT * FROM table ');
件数出力
echo $res->rowCount();
ありがとうございます。
仰る通りにやってみたのですがほんとに情けなくなるのですがまだできません。
アマゾンで評価が高かった本を買ってみたもののどうやら古いらしくアドバイス頂いた$resやPDO については調べても何も書いてありませんでした…
その結果
Notice: Undefined variable: db in C:\xampp\htdocs\pub004\src\kensaku.php on line 67
のエラーが出てしまいます。
既にちゃんと動いている
$sql =("SELECT*FROM estate WHERE 価格 BETWEEN $price1 AND $price2 AND 駅距離1 BETWEEN $minute1 AND $minute2 AND 市区町村 ='$area1'");
こちらからコピーをしてるのでつまらないミスはないと思うのですがなぜでしょうか?
こちらがアドバイスを元に作ったものです。上記$sqlのすぐ下に置いております。
$res = $db->query("SELECT*FROM estate WHERE 価格 BETWEEN $price1 AND $price2 AND 駅距離1 BETWEEN $minute1 AND $minute2 AND 市区町村 ='$area1'");
echo $res->rowCount();
何度もお付き合い頂いて恐縮ですがよろしくお願いいたします。
No.7
- 回答日時:
ひとつ気になるんですが、
phpにはmysqlにアクセスする手段が複数あるんですが、mysql_query()でmysqlにアクセスしてますよね?
pdoとかmysqliとかでないですね?
方法ごとにコマンド群が微妙に違いますから、mysql_query()以外で検索かけた場合、件数の摂りかたが変わりますよ。
アドバイスありがとうございます。
お返事が遅くなってしまい申し訳ございません。
そもそもmysql_query()自体使ってないと思います。
なんとなくそのあたりが自分でもあまり理解できてなく、
ネットでみなさんが使ってる手段と比べると私の手法はマイノリティな気がしています。
とりあえず改めて本を買って現在にらめっこをしているところです。
やっぱりそのあたりの基礎がわかっていないのかなと。。。
No.6
- 回答日時:
こんにちは。
エラーが発生している行が67行目なので、
そのあたりをコピペで掲載できますか?
できれば1から67行目まであれば有難いです・・・。
※個人情報に当たる部分はマスクしてください。
こんばんわ。
完全に諦めていてお返事が遅くなって申し訳ありません。
以下、SQLについて記載いたします。
先日色々試した時と多少の行のずれはあるかもしれませんが、phpの頭から終わりまで記載いたしました。(一部大勢に影響がない範囲で表示しておりませんが)
エラーメッセージは
Warning: mysql_num_rows() expects parameter 1 to be resource, boolean given in C:\xampp\htdocs\pub004\src\kensakuQQQ.php on line 68
という記載になっております。
たびたびお力添え頂きありがとうございます。
よろしくお願いいたします。
42 <?php
43 $area1=$_POST['area1'];
44 $price1=$_POST['price1'];
45 $price2=$_POST['price2'];
46 $minute1=$_POST['minute1'];
47 $minute2=$_POST['minute2'];
48
49
50 $dsn ='mysql:dbname=phpkiso;host=localhost';
51 $user ='root';
52 $password ='';
53 $dbh = new PDO($dsn,$user,$password);
54 $dbh->query('SET NAMES UTF-8');
55
56
57 $sql ="SELECT*FROM estate WHERE 価格 BETWEEN $price1 AND $price2 AND 駅距離1 BETWEEN $minute1 AND $minute2 AND 市区町村 ='$area1'";
58 $stmt =$dbh->prepare($sql);
59 $data[]=$price1;
60 $data[]=$price2;
61 $data[]=$minute1;
62 $data[]=$minute2;
63 $data[]=$area1;
64
65 $stmt->execute($data);
66
67 $test1=mysql_query($sql);
68 print mysql_num_rows($test1) . '件の検索結果が表示されました';
69
70 while(1)
71 {
72$rec =$stmt->fetch(PDO::FETCH_ASSOC);
73if($rec==false)
74{
75break;
76}
77echo '<table border="1" cellspacing=0 cellpadding=5 width=770>';
78
79echo '<tr><td width="25%">施設名</td>';
80echo '<td width="10%">価格</td>';
81echo '<td width="15%">交通</td>';
82echo '<td width="20%">所在地</td>';
85echo '<td width="8%">リンク</td></tr>';
86
87
88echo '<tr><td>'.$rec['施設名'].'</td>';
89echo '<td>'.$rec['価格'].'万円</td>';
90echo '<td>'.$rec['交通'].'</br>'.$rec['最寄駅1'].' '.$rec['駅距離1'].'分 91</td>';
92echo '<td>'.$rec['所在地'].'</td>';
95echo '<td><a href="'.$rec['URL'].'"></a></td></tr>';
96echo '</table>';
97echo '</br>';
98
99 }
100
101
102 $dbh =null;
103 ?>
No.5
- 回答日時:
もしかして件数表示の行で何かタイプミスとかしてないですか?
あるいは
echo mysql_num_rows($r);
とか
print_r($r);
したらどうなりますか?($rはmysql_queryの結果セット)
いろいろとやり方を教えて頂きありがとうございます。
thezen5さんの仰るようにやりながら、何か落ち度はないかとあれこれやってみたのですがどうにもうまくいきませんでした。
自分にはまだ早かったのかと思い、今回は諦めることにしました。
たびたびアドバイス頂き本当にありがとうございました。
No.4
- 回答日時:
こんばんは。
>>元になっているSQLからの呼び出しは正常に作動していて、検索結果も思った通りに表示されているのです。
だとすれば、そこで
変数1=mysql_query($sql);
while (変数2=mysql_fetch_row) {
・・・
とかってやってますよね?
この変数1を
mysql_num_rows(変数1)
とすれば、エラーにはならないはずですが・・・。
たびたびありがとうございます。
どうにもおっしゃる通りやってみているのですができませんでした。
ロジックも理解して他に自分のミスがないか確認はしているのですがうまくいきませんでした。
taka451213さんには何度もお答え頂いて恐縮なのですが諦めることにしました。
本当にありがとうございました。
No.3
- 回答日時:
こんにちは。
>>Warning: mysql_num_rows() expects parameter 1 to be resource, boolean given
SQLエラーです・・・。
エラーにならないSQLを実行してください。
ありがとうございます。
しつこくてすみません。
SQLエラーについて調べてみました。
元になっているSQLからの呼び出しは正常に作動していて、検索結果も思った通りに表示されているのです。
ですが、検索件数の本来数字を出したい箇所だけにエラーが表示されている状態です。
ちなみに質問をさせていただいた記述は簡素化していて実際のプログラムではBETWEENを複数回使用して検索をしています。ご相談させて頂いた前提条件に問題があるのでしょうか?
$sql ="SELECT*FROM estate WHERE 価格 BETWEEN $price1 AND $price2 AND 駅距離1 BETWEEN $minute1 AND $minute2 AND 市区町村 ='$area1'";
実際に使用したSQLです。
たびたび恐縮ですがよろしくお願いいたします。
No.2
- 回答日時:
これではだめですか?
ちなみにmysql_num_fieldsは件数じゃなくてフィールド数を取得するコマンドですが
$r = mysql_query("SELECT * FROM estate WHERE 価格 BETWEEN $price1 AND $price2");
print mysql_num_rows($r) . "\n件の検索結果が表示されました";
お返事ありがとうございます!
さっそくやってみたのですが
print mysql_num_rows($r) . "\n件の検索結果が表示されました";
この記述に対して
Warning: mysql_num_rows() expects parameter 1 to be resource, boolean given in C:\xampp\htdocs\pub004\src\kensaku.php on line 67
件の検索結果が表示されました
というエラーが出てきてしまいました。
頂いたソースの前半は何も出てこなかったのでうまく働いているみたいです。
print の指示の際に何か注意しなければならないことあるのでしょうか?
No.1
- 回答日時:
こんにちは。
そもそも、'(シングルコーテーション)で囲ったら駄目です。
ただの文字列になっちゃいますよ・・・。
件数の取得は、
mysql_num_rows()
です。
それから、引数に渡すのはSQL文字列でなくて実行結果のリソースです。
なので、件数だけほしいなら、
$sql ="SELECT*FROM estate WHERE 価格 BETWEEN $price1 AND $price2";
print mysql_num_rows(mysql_query($sql)) . '件の検索結果が表示されました';
みたいになりますが?
さっそくの投稿ありがとうございます。
print mysql_num_rows(mysql_query($sql)) . '件の検索結果が表示されました';
この結果が
Warning: mysql_num_rows() expects parameter 1 to be resource, boolean given in C:\xampp\htdocs\pub004\src\kensaku.php on line 66 件の検索結果が表示されました
というエラーが出てしまいます。
何か根本的な設定などでいまひとつな部分があったりするものなのでしょうか?
無知で恐縮ですがお願いいします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~1/20】 追い込まれた犯人が咄嗟に言った一言とは?
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・【選手権お題その3】この画像で一言【大喜利】
- ・【お題】逆襲の桃太郎
- ・自分独自の健康法はある?
- ・最強の防寒、あったか術を教えてください!
- ・【大喜利】【投稿~1/9】 忍者がやってるYouTubeが炎上してしまった理由
- ・歳とったな〜〜と思ったことは?
- ・ちょっと先の未来クイズ第6問
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
DB(MySQL)から複数行のデータを...
-
Resource id #3 をフィールドの...
-
mariadbでのエラー
-
PHP+mysqlでSQL文に文字数制限...
-
sqlから多次元配列に要素を格納...
-
MySQLでデータベースにデータin...
-
phpで複数の検索語を検索対象に...
-
実行時エラー3131 FROM 句の構...
-
PHP+SQLite でSELECT文のWHERE...
-
csvをDBへ読み込んだら、NULLが...
-
VBAをつかってクエリの情報を抽...
-
Pro*Cの構文エラー
-
PHP+MySQLでの配列のinsert文に...
-
phpを使って、絞り込み検索、条...
-
検索結果が多い時の分割(件数...
-
PHPでMySQLのデータを2次元配...
-
MySQLのINSERT時にたまに重複に...
-
文字化けが解決できません。お...
-
MySQLにHTMLタグを挿入したい
-
SQLのSUM関数で取得した値を参...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
stringaddslashes 半角¥が消える
-
PHP+mysqlでSQL文に文字数制限...
-
ボタンのonclick時における関数...
-
phpのエラーについてです
-
mysql_query等でレコード数を変...
-
SQLの結果が返ってこない
-
phpからMySQLへ日本語insert
-
会員登録したらメールが送られ...
-
縦に長い<table>でなく横に長い...
-
sqlから多次元配列に要素を格納...
-
XAMPPで画面が真っ白になります。
-
Resource id #3 をフィールドの...
-
PHP+MYSQLで直近3件のデータ表示
-
テーブルのレコード数を取得し...
-
XAMMPが起動しません。
-
DB(MySQL)から複数行のデータを...
-
テーブルに入っているデータと...
-
配列に値が入らない
-
MySQLのデータを使ってプルダウ...
-
if文で、レコードが無い場合だ...
おすすめ情報