![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?8acaa2e)
下記のようなテーブルがあったとして、
テーブルAを基準に考えたいのですが、、、、
テーブルAに付加する形でテーブルBのデータのidカウント数が最も少なく、idが同じもの中でdate日が一番新しいデータを表示し、古いものから並べかえかつテーブルCにidがあるものは一番最後にくるという風に並べかえたいのですが、無理でしょうか?
現在下記のようなSQLを考えていますが、うまくいかないです。。
select * from A left join(select id,case when count(id)=0 then 0 else count(id) end AS cnt FROM B group by id order by date) as b on A.id=b.id left join(select id from C) as c on A.id=c.id order by c.id desc,b.cnt;
エラー↓
in the GROUP BY clause or be used in an aggregate function
テーブルA
id | name | comment|
1 あ おい
2 い えい
3 か テス
テーブルB
id | event | date |
1 test1 2005/1/4
2 test1 2005/1/4
1 test2 2005/3/4
2 test2 2005/3/4
1 test3 2005/5/4
テーブルC
id |
1
理想の結合データ
id | name | comment| cnt | date |
3 か テス 0
2 い えい 2 2005/3/4
1 あ おい 3 2005/5/4
No.1ベストアンサー
- 回答日時:
内部結合で。
select A.id,A.name,A.comment,
count(B.id) as cnt,
max(B.date) as date,
'0' as CK
from A,B
where B.id=A.id and not exists(
select id from C where C.id=A.id
)
group by A.id,A.name,A.comment
UNION
select A.id,A.name,A.comment,
0 as cnt,
NULL as date,
'0' as CK
from A
where not exists(
select id from C where C.id=A.id
)
and not exists(
select id from B where B.id=A.id
)
group by A.id,A.name,A.comment
UNION
select A.id,A.name,A.comment,
count(B.id) as cnt,
max(B.date) as date,
'1' as CK
from A,B,C
where B.id=A.id and C.id=A.id
group by A.id,A.name,A.comment
UNION
select A.id,A.name,A.comment,
0 as cnt,
NULL as date,
'1' as CK
from A,C
where C.id=A.id and not exists(
select id from B where B.id=A.id
)
group by A.id,A.name,A.comment
order by CK,cnt;
こんなにいっぱい書いていただきありがとうございます。
でも、できませんでした。。なんででしょう。。
adding missing FROM-clause entry in subquery for table "A"
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Oracle SQL update方法 2 2022/06/22 14:07
- Oracle sqlで質問です。 aテーブルとbテーブルがあり、下記のsqlで取得したidとnameに一致しないレ 1 2022/04/20 20:34
- PostgreSQL 画像とカテゴリーを出力したいのですが、取得の条件を付ける方法がわかりません。 2 2022/05/01 18:03
- PHP コメント機能に返信欄を矢印で追加したい 1 2022/05/09 21:17
- Access(アクセス) アクセス 有効なフィールド名、または式として認識できませんのエラー 3 2022/08/19 11:53
- Access(アクセス) アクセス where句を使用して複数条件抽出をするには 2 2022/08/29 13:24
- PostgreSQL SQLで検索結果の記事を表示したい 1 2022/04/28 21:03
- MySQL SQLです。こんな感じですか?あってますか? うまくいきません教えてくださいお願いします 1 2023/07/08 15:27
- MySQL うまくいきません教えてくださいお願いしますSQLです。クエリ構文です。 1 2023/07/07 12:39
- Oracle sqlで質問です。 Aテーブルの情報をBテーブルに更新かけたいです。 やりたいことは、Bテーブルの受 1 2023/05/17 11:17
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
postgreSQLのint型は桁数指定が...
-
テーブルからのselectにおいて...
-
UNIQUEをつけたときのINDEXテー...
-
チェックボックスから、データ...
-
pg_queryで変数の取り扱い方
-
クエリアナライザのsp_helpコマ...
-
phpPgAdminからSQL文を発行し、...
-
特定カラムの値を変更したいの...
-
指定された趣味を持つメンバー...
-
データを削除しても表領域の使...
-
Viewにインデックスは張れ...
-
異なるスキーマからデータを抽...
-
CLOB型へのINSERT
-
DELETE文でFROM句を省略した場合
-
Access レコードを追加できませ...
-
ACCESS 複数テーブル・複数フィ...
-
datapumpの実行方法について
-
ORA-00959: 表領域'****'は...
-
他の処理でselectさせないよう...
-
【Access】外部結合を行う前に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
postgreSQLのint型は桁数指定が...
-
テーブルからのselectにおいて...
-
UNIQUEをつけたときのINDEXテー...
-
前方一致が動的に変更される場...
-
3つのテーブルの処理について
-
SQL文作成のお願い
-
postgreSQLのオートナンバーに...
-
クエリアナライザのsp_helpコマ...
-
SQL SELECT文 別テーブルのレコ...
-
SQLで検索結果の記事を表示したい
-
PostgressからMySQL(MariaDB)...
-
plpgsqlのエスケープ文字について
-
近い時間によるテーブル結合
-
マルチテーブル・インサート
-
講座のある日を抽出したい
-
特定カラムの値を変更したいの...
-
次の条件を満たすSQL文をご...
-
postgreSQLの正規表現
-
SQL文の実行に苦労しています。
-
phpPgAdminからSQL文を発行し、...
おすすめ情報