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

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

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

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

SQL

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

Q&A

解決済

1回答

11357閲覧

SQL 重複していない行の抽出

_LAGRANGE_

総合スコア44

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

SQL

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

0グッド

0クリップ

投稿2016/04/28 02:35

編集2016/04/28 02:42

以下の2つの条件でデータを検索したいのですがうまくいきません。

  1. 子テーブルのa列にある値は基本的に親テーブルのA列に属していなければならないが、属していないものがある。それを抽出せよ。

例:

子テーブル
a列
1
3
5
7

親テーブル
A列
1
2
3
5
6
8
10

→抽出される値は 7

  1. とあるテーブルのA列の値が等しい行のまとまりの中で、B列の値が違うものが存在する場合、そのA列の値を抽出せよ。なお、A列の値が等しい行が他にない場合はのぞく。

例:

A列 B列
1 5
1 4
1 5

2 3
2 3

3 1

4 2
4 2
4 2

5 1
5 2

→抽出される値は 1, 5

現状では、

1.

SELECT a列 FROM 子テーブル
LEFT OUTER JOIN 親テーブル
ON 子テーブルa列 = 親テーブルA列
where 子テーブルa列 is null

A列でグルーピングし、重複行数をカウント。
A列の値が等しい行の集合の中で重複した行数が上でカウントしたものよりすく泣けれb、仲間はずれが存在する
というSQL(まだできていません)

2は特にうまい方法がわかりません。
同じまとまりの中での重複していない行の抽出ってそもそもできるのでしょうか?よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんな感じでしょうか?

前者
SELECT c.a列 FROM 子テーブル AS c
WHERE NOT EXISTS
(
SELECT 1 FROM 親テーブル AS p
WHERE p.A列 = c.a列
)

後者
SELECT A列 FROM とあるテーブル
GROUP BY A列
HAVING MAX(B列) <> MIN(B列)

投稿2016/04/28 04:10

編集2016/04/28 04:11
hihijiji

総合スコア4150

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

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

_LAGRANGE_

2016/04/28 04:38

すごくスマートなやり方だと思います! とても助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問