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

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

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

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

PHP

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

2回答

2773閲覧

PHPmySQLでのページング処理について

otokichi_

総合スコア25

MySQL

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

PHP

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

1グッド

1クリップ

投稿2016/04/13 08:33

根本的にページャ?の仕組みがよくわかっていないですが、少し急いでいるため質問させていただきます。

順序としまして
① データベースにPDO接続する
② HTMLのformから入力された値とSELECT文のWHERE句を組み合わせて検索する。
③ 出力する

質問内容
③で出力された行数をカウントし、1ページごと10行にしたいです。
LIMIT句を使った制限(0~10行まで)とか
≪前へ | 次へ ≫ を出力するようなところまではできてます。
次へを押した際になにも表示されないので、どうしていいやら。

お詳しい方是非ご回答願います。
また、なにか参考になるサンプル等ありましたら教えていただきたいです。

現状
/-------------------------------------------------------/

~省略~

$query = "SELECT SQL_CALC_FOUND_ROWS * FROM {$table_name} WHERE " . join(" OR ", $where);
$stmt = $pdo->prepare($query);

foreach($target_columns as $index_column => $column){
foreach($keywords as $index_keyword => $keyword){
if(!$stmt->bindValue(":keyword{$index_column}_{$index_keyword}", "%{$keyword}%")) {
exit("Failed to bind value: " . $keyword);
}
}
}

$stmt->execute();

//行数の値を取得。executeのあとで取得可能。
$stmt2 = $pdo->query("SELECT FOUND_ROWS()");
$ret = $stmt2->fetch();
$hogehoge = $ret['FOUND_ROWS()'];

print($hogehoge."件がヒットしました"."<br>");

if ($stmt->execute()) {

if(2 < $hogehoge){ $Size=sizeof($hogehoge); $P = $_GET["p"]; if($P>0){ $Prev=$P-1; $PrevPage="<a href='index.php?p={$Prev}'>前 </a>"; } if($Size/10-1>$P){ $Next=$P+1; $NextPage="<a href='index.php?p={$Next}'> 次</a>"; }

//データベースの項目「備考欄」出力
while($col = $stmt->fetch(PDO::FETCH_ASSOC)){

print($col['備考欄']); } } }

}

?>

<form action="" method="post"> <p><input type="search" name="search" size="30" maxlength="255"placeholder="Search..."> <input type="submit" value="検索"></p>
<p> <input type="checkbox" name="search2" id="h_ac_i12" value="12"> <label for="h_ac_i12">熱海市</label> </p>
</form> </body>
act823👍を押しています

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

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

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

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

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

KiyoshiMotoki

2016/04/13 09:01 編集

データを取得するSQLにLIMIT句がない、データ取得の前にSELECT FOUND_ROWS()を実行しているなど、いくつかおかしいところが見受けられます。ソースコードは可能な限り生のまま貼り付けてください。さもないと、どこに問題があるのかわからなくなりますので。
otokichi_

2016/04/19 13:04

SELECT文にLIMIT句をつけるとこは省略してました。SELECT FOUND_ROWS()はこの位置で行数の取得ができているようです。
guest

回答2

0

http://qiita.com/mpyw/items/4ab192e04430119d5599
これどう?
http://dotinstall.com/lessons/paging_php_v2
これはページング機能の根本の説明

pearが使えるならpear pagerできるよ。
http://php-fan.org/pager-pear.html

投稿2016/04/13 08:41

編集2016/04/13 09:01
gik

総合スコア152

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

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

mpyw

2016/04/13 21:13

紹介ありがとうございます.この記事を書いた時には知らなかったのですが ・SQL_CALC_FOUND_ROWSをつけるとフルスキャンが走る ・OFFSETを使うとその該当オフセットまでスキャンが走る という大きな欠点があり,これらのスキャンは O(n) で実行されるため非常に遅いです.何万件と件数が増えてきたときにつらくなってくるはずです.(そうでもなければ気にしなくていいですが) http://qiita.com/mpyw/items/07c03600c2e38e91415e 一方こちらの方法であれば O(log n) の時間で済むので非常に高速です.ただし,絞り込みありの件数が求められなかったり,主キー以外でのソートができないという欠点はあります.
guest

0

先生が解決してくれました。
URLの末尾に
?search={入力された値}&page=

を付けるだけでした。
こんな簡単な事で良かったわけです。

投稿2016/04/29 08:17

otokichi_

総合スコア25

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問