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

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回答

1788閲覧

CakePHPでのSQLの書き方がわからない

退会済みユーザー

退会済みユーザー

総合スコア0

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/20 04:28

編集2018/06/20 04:30

いつもお世話になっています。
CakePHP2.xで顧客の情報を引き出したいのですが、書き方がどうしてもわからず、希望の結果が出ません。
以下の結果を導き出したい場合、どのように記述すれば良いのでしょうか?

顧客テーブル

顧客ID更新日
12018-06-25 15:21:00
22017-04-02 04:05:00
32018-02-17 14:29:00

商品テーブル

ID種別顧客ID登録日
1A12017-09-12 09:10:00
2A22017-10-06 13:33:00
3B12017-11-22 11:20:00
4A22018-01-05 01:24:00
5B22018-02-09 06:14:00

希望する結果
顧客テーブルの「更新日」、商品テーブルの「種別と顧客IDで絞った登録日」を比較して、一番最新の日時を引き出したい。

顧客ID一番新しい日付
12018-06-25 15:21:00
22018-02-09 06:14:00
32018-02-17 14:29:00

商品テーブルの情報絞り込みは、CASEでの分岐もあるので以下のようなサブクエリを作って顧客テーブルにJOINさせようとしていたのですが、商品テーブルに情報のある「顧客1」「顧客2」は「一番新しい日付」が取れても、「更新日」しかない「顧客3」の日付が取れなかったりと、根本的に繋げ方がおかしいようです。

MySQL

1GREATEST(COALESCE(MAX(商品テーブル, -2147483648)), COALESCE(更新日, -2147483648)) AS 一番新しい日付

本来、どのような書き方をするのが正しいのでしょうか?

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

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

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

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

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

m.ts10806

2018/06/20 04:32

「CakePHP サブクエリ」で調べれば情報は出てきますし、公式マニュアルにもサブクエリについて言及はありますが、それでは何が不足なのでしょうか?自身で調べて、やってみたこと、それで起きた問題を記載してください https://teratail.com/help/question-tips#questionTips1-2 >投稿前に自分で一度調べてみましょう。そして調べたことを元に、一度は自分でやってみましょう。
退会済みユーザー

退会済みユーザー

2018/06/20 04:37

済みません、もう丸一日あれこれ書き方を調べてやってみても希望の結果が出なかったので質問しました……。実行したSQLを直接貼ることが出来ないため、希望する結果について簡略で書いたのですが、もう少し追記します。
m.ts10806

2018/06/20 04:39

その「丸一日あれこれ書き方を調べてやってみて」がこの質問内容では伝わらないので指摘しています。現在の質問内容だけでは丸投げと同等であるためです。
退会済みユーザー

退会済みユーザー

2018/06/20 04:43

わかりました。取り下げます。ありがとうございました。
m.ts10806

2018/06/20 04:44 編集

いえ、質問に追記していただければそれで良いのですが・・ >自身で調べて、やってみたこと、それで起きた問題を記載してください
guest

回答1

0

わからないならPDO使え

投稿2018/06/22 04:59

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問