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

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

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

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

Q&A

解決済

1回答

2511閲覧

ページネーション機能でSQLクリエを減らす方法

退会済みユーザー

退会済みユーザー

総合スコア0

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

0グッド

0クリップ

投稿2017/02/22 12:39

編集2017/02/22 13:15

Codeigniter3でDBから取得した情報の一覧表示画面を作成しています。

パラメーターから絞り込んだ情報を取得して、20件ずつをページネーションしているのですが、
マッチする情報全件の数を取得するためのクエリと表示させる分のクエリの2回を行っているのですが、
これを1回のクエリで済ませれる方法はないでしょうか。

Codeigniterのヘルパーやメソッドを使用していますが独自の関数・メソッドを使用しているので分かりやすくSQL文にすると

A = SELECT カラム FROM テーブル名 WHERE 条件式 B = SELECT カラム FROM テーブル名 WHERE 条件式 limit 20 OFFSET ○, ▲ $all = count(A); echo '前' . $all . '件'; foreach(B as $line => $column){ ・・・ }

といったような処理になります。

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

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

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

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

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

guest

回答1

0

ベストアンサー

sql

1SELECT SQL_CALC_FOUND_ROWS カラム FROM テーブル名 WHERE 条件式 LIMIT 0, 20;

のあとで

sql

1SELECT FOUND_ROWS;

という代替手段もありますが、 いずれにしてもクエリを2回実行することに変わりはありません

SQL_CALC_FOUND_ROWS は MySQL のみの拡張機能なので、他のSQLでは利用できません。
また、MySQLだからと言って積極的に利用できるものかというとそうでもない。
データ数が多くなるとパフォーマンス低下が著しい。

ページングのためには、クエリを2回発行するのは、致し方ありません。他に方法はないです。

投稿2017/02/22 13:26

編集2017/02/22 13:28
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

退会済みユーザー

退会済みユーザー

2017/02/23 05:18

ご回答ありがとうございます。 クリエを2回発行するのはいたしかたないのですね。
退会済みユーザー

退会済みユーザー

2017/02/23 08:08

これ、 A = SELECT カラム FROM テーブル名 WHERE 条件式 を許容するなら、A から対象となる範囲のデータを抜き出せば、1クエリで実現できないですか? A が大きければ、絶対に許容しないし、あまり一般的ではないともうけど^^;
退会済みユーザー

退会済みユーザー

2017/02/23 09:54

Codeigniter3のページネーションクラスを使用しての実装は可能でしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問