DEVELOPERS BLOGデベロッパーズブログ

  1. HOME > 
  2. 加藤 正人のデベロッパーズブログ > 
  3. CakePHP の Paginator の sort() で昇順ソート時に NULL 値を最後にしたい

加藤 正人のデベロッパーズブログ

加藤 正人

氏名
加藤 正人
役職
多分SE
血液型
秘密
出没
美味しいもののあるところ
特色
タヒチ大好き。ちょいメタボ。

加藤 正人

2013/12/21

CakePHP の Paginator の sort() で昇順ソート時に NULL 値を最後にしたい

 

MySQL では NULL 値は昇順ソート時には最先頭、降順ソート時には最後尾になる仕様となっている。(これはデータベースエンジンごとに異なるらしい。)

しかし、この順序を変更したいこともままある。

そのような場合は ORDER 句の先頭に、例えば ISNULL({フィールド名}) ASC を追加することで対応できる。

例: 価格 price フィールドを昇順でソートしたいが、price フィールドが NULL のものは末尾に集めたい場合は次のようにする。

	... ORDER BY ISNULL(price) ASC, price ASC ...

さて、ここで問題が1つ。CakePHP の PaginatorHelper::sort() を使用してソート順を指定する場合、sort() メソッドにはソートフィールドを1つしか宣言できない。

いろいろ調べてみたところ、「5丁目通信(仮称)  CakePHP:paginateのsortに複数のソート項目を追加する。」という記事が非常に参考になった。

当該モデルの beforeFind() コールバックメソッドで特定の条件の時にのみ、クエリー配列の order 部に array('ISNULL(...)' => 'ASC') を追加する方法だ。これを利用して、

	public function beforeFind($query)
	{
		if ( @$query['order'] )
		{
			// クエリーにオーダー指定あり
			foreach ( $query['order'] as $order )
			{
				if ( strtoupper(@$order["{$this->name}.price"]) == 'ASC' )
				{
					// オーダー指定に price フィールドが ASC で指定されている場合は、オーダー配列の先頭に "ISNULL({モデル名}.price) ASC" を追加する
					array_unshift($query['order'], array("ISNULL({$this->name}.price)" => 'asc'));
					break;
				}
			}
		}
		return $query;
	}

のようにすることで所期の目的を達成することができる。

関連タグ: CakePHP2  PaginatorHelper 

関連エントリー

CakePHP のレンダリング結果を保存したい

CakePHP 2.x の Cookie と js.cookie.js

時刻入力用 jQuery Plugin TimePicki の不具合調整

CakePHP プラグインで HTTPS 判定

作業用モデルビヘイビア

CakePHP のバリデーション時に状況に応じてバリデーションルールを変更する

CsvLoader ビヘイビアを使って CSV を一発でロードする Cake Shell

CakePHP の Security コンポーネント、ベーシック認証、CGI

形態素解析システム MeCab (めかぶ) を CakePHP から利用する

Google APIs Client Library を CakePHP から利用する

分数電卓を作ってみる・その2

分数電卓を作ってみる・その1

CsvLoaderBhavior - CSV データを CakePHP で扱うための一手法・その2

 CsvLoaderBhavior - CSV データを CakePHP で扱うための一手法

CakePHP でストアドファンクション

テキストフィールドを CSV として処理する CakePHP ビヘイビア・補足

テキストフィールドを CSV として処理する CakePHP ビヘイビア・その2

テキストフィールドを CSV として処理する CakePHP ビヘイビア・その1

Google Maps で郵便番号⇒住所変換・その2

テキストを自動整形する簡易 CakePHP ヘルパー

Google Chart へのアクセスをヘルパーで実装してみる【その2】

Google Chart へのアクセスをヘルパーで実装してみる【その1】

Google reCAPTCHA を使いやすくする

駅データ.jp のデータを CakePHP から使う

CakePHP の小ネタ

UploadPack を Exif Orientation 対応にする

作業用テーブル処理を再利用可能なツール化してみる・その1

クリックイベントが2回実行される?!

CakePHP のフォームで required・その2

CakePHP のフォームで required

UploadPack のヘルパーメソッド名称が変わっていた

CakePHP 2.x の PaginatorHelper::sort の不思議

CakePHP で四苦八苦 - あるフィールドにだけ値が書き込まれない

UploadPack で四苦Hack その後

CakePHP の小ネタ

CakePHP v2 のエラー処理

IE10 と CKEditor

2013/03/23
IE10 と CKEditor

UploadPack で四苦Hack・その2

Paginator で見かけの URL を使用する方法

「Notes プラグインが見つかりません」

CakePHP v2 で HTTP エラー画面をカスタマイズする

UploadPack で四苦Hack

PHP 5.4 と CakePHP 2.x