猫型iPS細胞研究所

Windows、Linux、iOS、DB、Network

未分類

CakePHPでSQLを直接実行する

投稿日:

正直find等を使用するのは面倒です。
SQLを直接実行するには以下のようにします。

 $sql='select count(*) as cnt, referer from acls where controller=\''.$this->name.'\' and action=\''.$this->action.'\' and role like (select concat(\'%\',role,\'%\') from users where id ='.$this->Auth->user('id').' and del_flg=\'0\') and del_flg=\'0\'';
                        Debugger::dump($sql);
                        $data=$this->User->query($sql);

$dataに入った値を取り出すのは以下の通りです。
分からなければ一度Debuggerで変数の中身を確認しましょう。

if($data[0][0]['cnt'] !== '1'){
                                $this->Session->setFlash(__('Authentication failed'));
                                $this->redirect($this->Auth->logout());
                        }

Gooleアドセンス用336

Gooleアドセンス用336

-未分類
-,

執筆者:

関連記事

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

たとえばMySQLのconcatを使用して文字列を結合したいとします。 $data = $this->Company->find(‘list’, array( ‘fields’=>a …

CakePHPでControllerからViewへデータを渡す時の注意点

Controller側で $this->set(‘hensu’,$role); $this->set(‘aaa’,’xxx’); としてやれば、View側で ; ; として値を取り出すこと …

asp

IISの設定

Visual StudioでLocalに配置したサイトが、ブラウザで表示できず、下記エラーが表示された場合の対処法です。 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ …

CakePHPのVaridationのalphaNumeric(半角英数字)は正常に機能しない

alphaNumeric(半角英数字)だけは何故か機能せずにパスしてしまいました。 カスタムチェックにするのが一番手っ取り早いようです。 応用すればオリジナルVaridationが簡単に作成できます。 …

CakePHPのlayoutを指定する

ログイン画面ではメニューが不要であったりと、 レイアウトを変更したい場合はコントローラーのアクションで以下のように指定します。 View/Layout/配下に作成したレイアウトを指定すればよいのですが …