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

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

ただいまの
回答率

90.76%

  • PHP

    19196questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • CakePHP

    2217questions

    CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

CakePHP3.5で直接クエリの結果をSelectBoxに入れたい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 211

gekota

score 2

CakePHP3でストアドプロシージャを使って、複雑なクエリ結果をSelectBoxに入れたいです。

ConnectionManager::getを使って、ストアドプロシージャからデータ抽出は出来ていますが、配列の配列みたいになってしまい、ビューのSelectBoxに入れると表示内容が入れ子になってしまいます。
ストアドと同じクエリをTableRegistry::getで処理すると問題無くSelectBoxに入れる事が出来ます。

デバッグで、抽出したデータを見ると、下記のような違いがありました。
直接クエリの結果をSelectBoxに入れには、どうしたら宜しいでしょうか?

/// TableRegistry::getで抽出したデータ
Array
(
    [1] => なまえ1
    [2] => なまえ2
    [3] => なまえ3
)

/// ConnectionManager::getで抽出したデータ
Array
(
    [0] => Array
        (
            [id] => 1
            [name] => なまえ1
        )

    [1] => Array
        (
            [id] => 2
            [name] => なまえ3
        )

    [2] => Array
        (
            [id] => 3
            [name] => なまえ3
        )
)
$this->mTest = TableRegistry::get('m_tests');
$date1 = $this->mTest->find()
        ->where(['is_deleted' => 0])
        ->select(['id', 'name'])
        ->combine('id', 'name')
        ->toArray();
print_r($date1);

$connection = ConnectionManager::get('default');
$date2 = $connection->execute('call st_test_1;')->fetchAll('assoc');
print_r($date2);
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

check解決した方法

0

PHPのarray_column()というので解決しました!

$connection = ConnectionManager::get('default');
$date3 = $connection->execute('call st_test_1;')->fetchAll('assoc');
$date2 = array_column($date3, 'id','name');  // 追加
print_r($date2);

参考
https://qiita.com/harukasan/items/a0773aef27d838852e44

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.76%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    cakephp での条件付きのpaginate()を行いたい

    こんにちは。 cakephpを使用して、条件付きの値を取得したいのですが、うまくできずに困っています。 行いたいことは、hasMany でアソシエーションしている別モデ

  • 解決済

    cakephp3 レイアウト内でのモデル呼び出しについて

    UsersHelper.phpを作成し、その中でUsersテーブルからユーザー名を取得して出力するだけの機能を作成したいと考えています。 ひとまず、UsersHelper.p

  • 解決済

    SelectBoxのselected

    やりたいこと DBから引っ張ってきたデータを修正用のフォームに反映させ、セレクトボックスで修正する。 その際に、項目が当然出るのはもちろんだけど、そのデータでselectedし

  • 解決済

    CakePHPのフォームでArray to string conversionエラー

    前提・実現したいこと PHP(CakePHP)で入力確認画面付きお問合せフォームを作っています。   日付入力を実装中に以下のエラーメッセージが発生しました。 発生してい

  • 解決済

    cakephp3 で afterfind 代わりの formatResultsの使い方

    やりたいこと ・Socialsテーブル ・Gazousテーブル の2つをcontain。 Gazousテーブルに画像があればそれをアイコンとする。 なければS

  • 解決済

    CakePHP3のGETで受け取ったパラメータのDB追加の仕方

    質問概要 表題の通り、CakePHP3のフォームでないGETで受け取ったパラメータのDB追加の書き方が知りたく、 質問させて頂きます。 フォームによるPOST、GETのパラメ

  • 解決済

    CakePHP3で複数テーブルに一括でインサートしたい

    説明 shopテーブルへインサートしてから、そのIDを利用して shop_holidayテーブルへ複数行、インサートする方法が知りたいです。 <inpu type="te

  • 受付中

    cakephp のfindで検索フォーム

    下記の条件で、検索をしたいのですがスマートなやりかたが思いつきません。 ・名前 ・性別 ・年齢 ・学歴 これれは セレクトボックスで検索ボタンを一つ押してgetで値を取得してい

同じタグがついた質問を見る

  • PHP

    19196questions

    PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

  • CakePHP

    2217questions

    CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。