DEVELOPERS BLOGデベロッパーズブログ
- HOME >
- 加藤 正人のデベロッパーズブログ >
- テキストフィールドを CSV として処理する CakePHP ビヘイビア・その2
加藤 正人のデベロッパーズブログ
- 氏名
- 加藤 正人
- 役職
- 多分SE
- 血液型
- 秘密
- 出没
- 美味しいもののあるところ
- 特色
- タヒチ大好き。ちょいメタボ。
- 2020/12/15
- CakePHP3 のリダイレクトがうまく行かない例
- 2020/11/12
- Apache Bench
- 2020/10/05
- PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)
今回もテキストフィールドを CSV として処理するビヘイビアの作成を進める。
前回の取得用コールバックに引き続き、今回は保存時のコールバックを作成する。
データ保存時の変換
データ保存時には、beforeSave() コールバックで保存データをチェックし、該当するフィールドのデータをカンマ区切り文字列に変換する。渡されたデーがが空配列や空文字列の場合は '' (空文字列) に変換する。
絞り込み条件の変換
最後に、find() 時の検索式の変換処理を beforeFind() コールバックで行なう。条件の変換は再帰処理になるので、プライベートメソッド __condition_replace() として独立させておく。
__condition_replace() の内部処理では、簡単のため条件配列のキーは {モデル名}.{フィールド名} のみ、値はスカラー値のみ (整数のみ) としており、!= や大小比較、IN 演算、あるいは MySQL 関数呼び出しには対応していない。
__condition_replace() では、CSV フィールドを検出すると、その {モデル名}.{フィールド名} => {値} の組を次の「OR」形式に変換する。
'OR' => array( "{モデル名}.{フィールド名} LIKE" => "{値}", // 値が単独値の場合 "{モデル名}.{フィールド名} LIKE" => "{値}{区切り文字}", // CSV形式の先頭にマッチ "{モデル名}.{フィールド名} LIKE" => "{区切り文字}{値}{区切り文字}", // CSV形式の途中にマッチ "{モデル名}.{フィールド名} LIKE" => "{区切り文字}{値}", // CSV形式の末尾にマッチ )
これにより、CSV フィールドに値が含まれるかどうかを文字列演算で行なうことができる。
この書き換えメソッドを beforeFind() コールバックで使用して条件配列を書き換える。実際のコードは下記のようになる。
以上で CSV フィールドへの対応が簡易的ではあるが可能となる。
関連エントリー
- 2018/04/14
- CakePHP のレンダリング結果を保存したい
- 2017/09/06
- CakePHP 2.x の Cookie と js.cookie.js
- 2017/07/08
- 時刻入力用 jQuery Plugin TimePicki の不具合調整
- 2017/06/18
- CakePHP プラグインで HTTPS 判定
- 2016/02/27
- 作業用モデルビヘイビア
- 2016/01/16
- CakePHP のバリデーション時に状況に応じてバリデーションルールを変更する
- 2015/10/24
- CsvLoader ビヘイビアを使って CSV を一発でロードする Cake Shell
- 2015/08/08
- 無名関数からの外部変数参照について
- 2015/07/04
- CakePHP の Security コンポーネント、ベーシック認証、CGI
- 2015/05/09
- 形態素解析システム MeCab (めかぶ) を CakePHP から利用する
- 2015/04/25
- Google APIs Client Library を CakePHP から利用する
- 2015/04/11
- 分数電卓を作ってみる・その2
- 2015/03/10
- 分数電卓を作ってみる・その1
- 2015/01/24
- CakePHP でストアドファンクション
- 2015/01/17
- テキストフィールドを CSV として処理する CakePHP ビヘイビア・補足
- 2014/12/13
- テキストフィールドを CSV として処理する CakePHP ビヘイビア・その1
- 2014/11/24
- Google Maps で郵便番号⇒住所変換・その2
- 2014/11/08
- Google Maps で郵便番号⇒住所変換
- 2014/10/25
- テキストを自動整形する簡易 CakePHP ヘルパー
- 2014/10/11
- Google Chart へのアクセスをヘルパーで実装してみる【その2】
- 2014/09/16
- Google Chart へのアクセスをヘルパーで実装してみる【その1】
- 2014/09/06
- Google reCAPTCHA を使いやすくする
- 2014/08/09
- 駅データ.jp のデータを CakePHP から使う
- 2014/07/26
- CakePHP の小ネタ
- 2014/07/03
- UploadPack を Exif Orientation 対応にする
- 2014/06/28
- 作業用テーブル処理を再利用可能なツール化してみる・その1
- 2014/03/08
- クリックイベントが2回実行される?!
- 2014/01/18
- CakePHP のフォームで required・その2
- 2013/12/07
- CakePHP のフォームで required
- 2013/11/23
- UploadPack のヘルパーメソッド名称が変わっていた
- 2013/11/09
- CakePHP 2.x の PaginatorHelper::sort の不思議
- 2013/07/13
- CakePHP で四苦八苦 - あるフィールドにだけ値が書き込まれない
- 2013/06/22
- UploadPack で四苦Hack その後
- 2013/05/25
- CakePHP の小ネタ
- 2013/04/29
- CakePHP v2 のエラー処理
- 2013/03/23
- IE10 と CKEditor
- 2013/02/09
- UploadPack で四苦Hack・その2
- 2013/01/26
- Paginator で見かけの URL を使用する方法
- 2013/01/12
- 「Notes プラグインが見つかりません」
- 2012/12/22
- PHP 5.3 の「無名関数」
- 2012/12/03
- CakePHP v2 で HTTP エラー画面をカスタマイズする
- 2012/11/12
- UploadPack で四苦Hack
- 2012/10/27
- PHP 5.4 と CakePHP 2.x
2020/12/15
2020/11/12
2020/10/05
2020/09/11
2020/08/03