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

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

新規登録して質問してみよう
ただいま回答率
85.48%
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

CakePHP

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

Q&A

解決済

1回答

685閲覧

cakePHP2でgroupbyをやるにはどうしたらいいでしょうか?

se_ariga

総合スコア11

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

CakePHP

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

0グッド

0クリップ

投稿2018/06/21 02:26

閲覧ありがとうございます。
下記のSQLとほぼ同じ処理をcakePHP2で行っているのですが、
SQLで言うGROUP BY Product.idの箇所をcakePHP2の書き方に直すやり方がわからず困っています。
みなさんのお力をお借りできればと思います、よろしくお願いいたします。

sql

1SELECT * FROM product INNER JOIN product_color ON product.id = product_color.product_id WHERE abolished_flg = 1 GROUP BY Product.id;

php

1if(!empty($_POST['abolished_flg'])){ 2 $params['joins'] = array( 3 array( 4 'type' => 'INNER', 5 'table' => 'product_color', 6 'alias' => 'ProductColor', 7 'conditions' => 'Product.id = ProductColor.product_id', 8 ), 9 ); 10 $params['conditions']['ProductColor.abolished_flg'] = $_POST['abolished_flg']; 11 $params['group'] = ['Product.id']; 12 }

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/06/21 02:54

そのドキュメントにある「GROUP BY は?」で説明が足りている気がするのだが。
退会済みユーザー

退会済みユーザー

2018/06/21 03:25

そもそもそのSQLは直接実行可能なのか?
se_ariga

2018/06/21 03:52

ドキュメントのご呈示ありがとうございます、該当箇所を読んで考えてみます!SQLにつきましては、正常に動いております。
m.ts10806

2018/06/21 03:57

まず何するにもドキュメント読みましょう。充実しているので余程特殊なことをやろうとしない限りドキュメントで事足ります。
se_ariga

2018/06/21 04:14

公式のドキュメントでは無いですが、いくつかのサイトを拝見して記述自体はしておりました。ですがgroupの記述が間違っているのか目的の結果が得られず困っていた次第でございます。ですが、他の箇所が不具合を起こしていたようで、groupの記述には問題が無いことがわかりました。皆さまご協力ありがとうございました!
guest

回答1

0

自己解決

別のプログラムで不具合を起こしていたようで、上記ソースのgroupの記述に問題はありませんでした。
大変お騒がせいたしました。

投稿2018/06/21 04:17

se_ariga

総合スコア11

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2018/06/21 04:35

そもそもですが「groupbyをやるにはどうしたらいい?」という質問でしたよね。 何が不具合が起きていたならそれはそれで前提として提示すべきでは? 問題と解決の場所が違うということはありえないわけではないですが、 単に「書き方が分からない」だけだと書き方の紹介だけになってしまい、 質問者さんが直面している問題の解決には至らないケースがあります。 次からで結構なので、質問に至った経緯や起きている問題(直面している問題)など背景を 書かれた方が意図した方向での回答がつきやすくなりますので、ご検討ください。
se_ariga

2018/06/21 05:08

groupbyの書き方が間違っていると思い込んでしまっていたため、正しい書き方をご教示いただこうと思いこのような質問にいたしました。 しかし、おっしゃる通りに質問の意図がわかりにくくご回答者様も質問者自身も空回りになっておりました。。 以降気をつけて参りますので、ご指導ご鞭撻のほどよろしくお願いいたします。
m.ts10806

2018/06/21 05:21

ひとまず解決したようで何よりです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問