猫型iPS細胞研究所

Windows、Linux、iOS、DB、Network

未分類

CakePHP findでMySQL関数を使用したい

投稿日:

たとえばMySQLのconcatを使用して文字列を結合したいとします。

$data = $this->Company->find('list',
    array(
        'fields'=>array('id','concat(comp_code,comp_name)'),
        'order'=>array('comp_code')
    )
);

とするとSQLは以下のようにテーブル名がついてしまいます。

SQL Query: SELECT `Company`.`id`, Company.concat(comp_code,comp_name) FROM `kddi`.`companies` AS `Company` WHERE 1 = 1 ORDER BY `comp_code` ASC

結論をいいますと、MySQL関数を利用するにはVirtualFieldsを使用する必要がります。
findの実行前にVirtualFieldsを設定して使用します。

Controllerでは以下のようにします。

$this->loadModel('Company');
$this->Company->virtualFields['name']='concat(Company.comp_code," : ",Company.comp_name)';
$data = $this->Company->find('list',
    array(
       'fields'=>array('id','name'),
       'order'=>array('comp_code')
    )
);
$this->set('compcodes',$data);

そしてView側では以下のように値を読み込みます。

          Form->input('comp_code',array('type'=>'select','options'=>array($compcodes)));
                echo $this->Form->input('comp_code',array('label'=>'企業コード'));
        ?>

このサンプルでは(企業コード:企業名称)という値をコンボボックスに設定しています。

Gooleアドセンス用336

Gooleアドセンス用336

-未分類
-,

執筆者:

関連記事

CakePHP 連想配列(POSTデータ)にデータを追加する。

$this->request->dataにデータを追加するにはどうすればいいのか悩みましたが以下の方法でできました。 CakePHPというよりPHPの話ですね・・・ $this->r …

asp

IIS(ASP.NET)ではネットワークドライブの割り当てを使ってはいけない

以前「タスクタスクスケジュールではネットワークドライブの割り当てを使ってはいけない」 という記事を記載したが、ASP上でも同じことが言えます。 ASPも実行するのがログインしているユーザーとはことなり …

strposの注意点

文字列が含まれているかどうかをチェックするには strposが高速です。 対象があれば0以上の値をかえしますが、 対象がなければfalseを返します。 そのため !== false の場合は対象データ …

CakePHPでセッションとクッキーの有効期限を設定する

./Config/core.phpを下記のようにすると ブラウザの保存するクッキーは有効期限0で、ブラウザを終了すればなくなります。 一方データベースに保存するセッション情報は15分でなくなるので、 …

CakePHP FormHelperでhidden属性を設定する

ユーザーIDなどのラベルなどで使用する変更できない値などを渡す場合に便利です。 echo $this->Form->hidden(‘User.cust_code’ ,array(‘valu …