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

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

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

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

VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

Q&A

解決済

2回答

38605閲覧

UNION句でまとめたテーブルに対してCOUNTしたい

f-hanako

総合スコア159

SQL

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

VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

0グッド

1クリップ

投稿2017/05/25 09:31

編集2017/05/25 09:57

MDBからレコードを読み込み、
データグリッド・フォームに内容を表示させるアプリを作成しています。

現在、データを読み込む際のSQLの作成で詰まっております。

下記のような2つのテーブル(Table_1, Table_2)があります。
今回、SQLで、二つのテーブルをUNION句で結合し、
更に「SEX」と「ADDRESS」の組み合わせの件数を取得したテーブル(DUAL_TABLE)を抽出したいです。
現在、下記のSQLでテーブルを結合するところまではうまくいったのですが、
「SEX」と「ADDRESS」の組み合わせの件数を取得するところがうまくいきません。

イメージ説明

SQL

1SELECT * FROM 2( 3SELECT ID, NAME, AGE, SEX, ADDRESS, '' AS PHONE FROM Table_1 4UNION 5SELECT ID, NAME, AGE, SEX, ADDRESS, PHONE FROM Table_2 6) AS DUAL_TABLE

上記のような場合、どのようなSQLを書けばよろしいでしょうか。


下記のようなSQLを作成すると、
「クエリに、集計関数として使用された式'ID'が含まれておりません。」
というエラーが出てしまいます。

SQL

1SELECT ID, NAME, AGE, SEX, ADDRESS, PHONE, SEADD FROM ( 2SELECT ID, NAME, AGE, SEX, ADDRESS, '' AS PHONE, (SEX & ADDRESS) AS SEADD FROM Table_1 3UNION 4SELECT ID, NAME, AGE, SEX, ADDRESS, PHONE, (SEX & ADDRESS) AS SEADD FROM Table_2 5) AS DUAL_TABLE; 6

■開発環境

・作成アプリケーションの種類:Windowsフォーム
・開発環境:Windows7 64bit/Visual Studio Professional 2012 /.NET Framework 4

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

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

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

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

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

hihijiji

2017/05/25 09:49

MASAYO の COUNT が 1 で HANAKO は 2 ですが、法則が解りません。
f-hanako

2017/05/25 09:54

失礼いたしました。MASAYOもHANAKOもCOUNTは 2 になります。
workaholist

2017/05/25 10:13 編集

COUNTは人に属する情報ではなく組合せの情報ですね?
guest

回答2

0

SqlServer環境が無いのでMYSqlですが

sql

1SELECT id, name, age, t1.sex, t1.address, phone, count FROM 2 (SELECT id, name, age, sex, address, '' phone FROM Table_1 3 UNION ALL 4 SELECT id, name, age, sex, address, phone FROM Table_2) t1 5JOIN 6 (SELECT sex, address, count(*) count FROM 7 (SELECT sex, address FROM Table_1 8 UNION ALL 9 SELECT sex, address FROM Table_2) t2 10 GROUP BY 1 ,2) t3 11USING (sex, address) 12ORDER BY 1;

投稿2017/05/25 15:46

A.Ichi

総合スコア4070

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

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

f-hanako

2017/05/26 06:59

回答ありがとうございます。 MySqlは使用したことがないのですが、 JOINの記載方法が異なっているんですね。
guest

0

ベストアンサー

こんな感じですか?

SQL

1SELECT 2 MAIN.ID, 3 MAIN.NAME, 4 MAIN.AGE, 5 MAIN.SEX, 6 MAIN.ADDRESS, 7 MAIN.PHONE, 8 SEADD.CNT 9FROM 10 ( 11 SELECT ID, NAME, AGE, SEX, ADDRESS, NULL AS PHONE FROM Table_1 12 UNION ALL 13 SELECT ID, NAME, AGE, SEX, ADDRESS, PHONE FROM Table_2 14 ) AS MAIN 15 LEFT JOIN 16 ( 17 SELECT 18 SEX, 19 ADDRESS, 20 COUNT(*) AS CNT 21 FROM 22 ( 23 SELECT SEX, ADDRESS FROM Table_1 24 UNION ALL 25 SELECT SEX, ADDRESS FROM Table_2 26 ) AS XXX 27 GROUP BY 28 SEX, 29 ADDRESS 30 ) AS SEADD 31 ON 32 MAIN.SEX = SEADD.SEX AND 33 MAIN.ADDRESS = SEADD.ADDRESS 34ORDER BY 35 MAIN.ID

投稿2017/05/25 10:27

workaholist

総合スコア559

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

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

f-hanako

2017/05/26 06:58

回答ありがとうございました。 目的のデータを取得することができました。 COUNTだけ取得したクエリを結合しているんですね。 勉強になりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問