サイトアイコン ITC Media

【必読】SQLで複数条件をしていする方法|実例付きで徹底解説

(最終更新月:2023年6月)

✔以下の疑問をお持ちの方へ向けた記事です

「SQLで複数の条件を指定する方法とは何で、どのように使うのだろうか?」
「SQLでの複数条件の使い方を学びたい」
「SQLで複数条件を指定した具体的な使用例を見て理解したい」

✔この記事を読むことで得られる知識

当記事では、SQLで複数の条件を指定する基本的な使い方だけでなく、具体的な例を用いて詳しく説明します。

ぜひ最後までお読みください。

筆者プロフィール

【現職】プロダクトマネージャー

【副業】ブログ(月間20万PV)/YouTube/Web・アプリ制作

「プログラミング × ライティング × 営業」の経験を活かし、30後半からのIT系職へシフト。現在はプロダクトマネージャーとして、さまざまな関係者の間に入り奮闘してます。当サイトでは、実際に手を動かせるWebアプリの開発を通じて、プログラミングはもちろん、IT職に必要な情報を提供していきます。

【当ブログで紹介しているサイト】

当サイトチュートリアルで作成したデモ版日報アプリ

Django × Reactで開発したツール系Webアプリ

✔人に見せても恥ずかしくないコードを書こう

「リーダブルコード」は、わかりやすく良いコードの定義を教えてくれる本です。

  • 見るからにきれいなコードの書き方
  • コードの分割方法
  • 変数や関数の命名規則

エンジニアのスタンダートとすべき基準を一から解説しています。

何回も読むのに値する本なので、ぜひ手にとって読んでみてください。

SQLにおける複数条件の基本

こちらでは、SQLにおける複数条件の基本についてお伝えしていきます。

複数条件の設定はデータの抽出や分析において非常に重要なスキル。

まずは基本から理解して、より効果的にデータベースを活用しましょう。

SQLでの複数条件設定の重要性

SQLでの複数条件設定は、大量のデータから必要な情報だけを選択・抽出するための非常に重要な手法です。

例えば、特定の地域の特定の年齢層のユーザー情報を抽出したい場合、地域と年齢という2つの条件を設定する必要があります。

これは一つの条件だけでデータをフィルタリングするよりも遥かに精度の高い情報抽出を可能にするのです。

複数条件を使うための基本構文

SQLで複数条件を設定するためには、基本的には”AND”および”OR”といった論理演算子を用います。

“AND”はすべての条件が真である場合に真を返し、”OR”は少なくとも一つの条件が真である場合に真を返します。

age >= 20 AND age <= 30

年齢が20歳以上30歳以下のデータを抽出する条件式になります。

複数条件を指定するための基本的なコマンド

次に、具体的なコマンドを使って複数条件を指定する方法を見ていきましょう。

ここでは、「AND」、「OR」、「BETWEEN」という基本的なコマンドについて説明します。

AND演算子を使った条件指定方法

「AND」演算子を使用することで、複数の条件を全て満たすデータの抽出が可能です。

age >= 20 AND gender = 'Female'

これは年齢が20歳以上かつ女性のデータを抽出するクエリです。

これにより、より具体的な情報を抽出することが可能となります。

OR演算子を使った条件指定方法

「OR」演算子を使用すると、複数条件のいずれかを満たすデータを抽出できます。

age < 20 OR age > 60

年齢が20歳未満または60歳以上のデータを抽出しています。

複数の範囲またはカテゴリからデータの選択が可能です。

ANDとORの併用方法

また、ANDとORを組み合わせることで、より複雑な条件を作成することも可能です。

age >= 20 AND (city = 'Tokyo' OR city = 'Osaka')

年齢が20歳以上で、かつ、都市が東京または大阪のデータを抽出できます。

BETWEENの使用例

一方、「BETWEEN」演算子を用いると、特定の範囲を指定できます。

age BETWEEN 20 AND 30

年齢が20歳から30歳までのデータを抽出するクエリです。

この方法は、特定の範囲内のデータを抽出する際に非常に有用です。

詳しくはこちらもご覧ください。

IN演算子を使用した複数の値の条件指定

次に、複数の値を一度に条件にするための「IN」演算子について見ていきましょう。

IN演算子を使えば、一度に複数の値を条件に設定することが可能となります。

IN演算子の基本的な使い方

IN演算子を使用すると、特定の列が複数の値のいずれかに一致するデータを抽出できます。

city IN ('Tokyo', 'Osaka', 'Nagoya')

こちらのクエリでは、都市が東京、大阪、名古屋のいずれかのデータを抽出できます。

OR演算子を用いた方法よりも記述が簡単で、大量の値を列挙する場合に特に有効です。

IN演算子についてはこちらをご覧ください。

INとサブクエリを併用した条件指定方法

さらに、IN演算子はサブクエリと組み合わせることも可能です。

サブクエリは、SQL文の中に書かれた別のSQL文のことで、クエリ内で複数の操作が可能になります

SELECT * FROM users WHERE city IN (SELECT city FROM cities WHERE population > 1000000);

人口が100万人以上の都市に住んでいるユーザを抽出する方法です。

実際の例を使った複数条件の使用方法

ここでは、実際のデータを使用して複数条件を活用する方法を具体的に見ていきましょう。

ANDとORを使った例

顧客データベースから年齢が20歳以上かつ男性、または年齢が25歳以上かつ女性の顧客を検索する場合の方法をご紹介します。

SELECT * FROM customers WHERE (age >= 20 AND gender = 'Male') OR (age >= 25 AND gender = 'Female');

WHEREとOR、ANDで指定した条件を満たす顧客のリストを取得しています。

INを用いた例

次に、「IN」演算子を用いた例を見てみましょう。

特定の商品IDを持つ商品を検索する例です。

SELECT * FROM products WHERE product_id IN (1, 2, 3, 4, 5)

これにより、指定したIDを持つ商品を一度に抽出することが可能となります。

SQLの複数条件の応用

ここでは、複数の条件をさらに高度に活用するための方法を見ていきます。

SQLを使ったデータベース操作の中でも特に複雑な部分であるため、しっかりと理解することが重要です。

複雑な条件の作成

複数条件の設定は単純なものから複雑なものまで幅広くあります。

例えば、年齢が20歳以上で性別が男性、もしくは年齢が25歳以上で性別が女性、という条件の場合、これをさらに「都市が東京または大阪、かつ購入金額が5000円以上」で絞り込むというようなことも可能です。

このように複数の条件を組み合わせることで、非常に具体的なデータ抽出が可能になります。

パフォーマンスを考慮した複数条件の設定

大量のデータが存在するデータベースでは、効率的なデータの抽出が求められます。

SQLクエリの実行速度は、設定した条件の複雑さやデータベースの設計により変わるからです。

以下のような特徴をおさえておきましょう。

条件の設定時にはパフォーマンスも考慮することが重要です。

複数条件の結合によるデータ抽出

ここでは、複数の条件を組み合わせてデータを抽出する方法を詳しく見ていきます。

このステップで、複数条件の活用をさらに深められます。

単一テーブルからのデータ抽出

単一テーブルからのデータ抽出では、ひとつのテーブルにあるデータに対し、複数の条件を組み合わせてデータを探します。

たとえば、ある商品のテーブルがあり、その中から価格が1,000円以上で、かつ評価が4以上の商品を見つけるといった具体的な条件を組み合わせてみます。

SQLでは「WHERE」句を使って抽出が可能。

SELECT * FROM 商品 WHERE 価格 >= 1000 AND 評価 >= 4;

複数テーブルからのデータ抽出

複数テーブルからのデータ抽出では、二つ以上のテーブルを結合し、各テーブルから特定の条件を満たすデータを見つます。

この方法は、リレーショナルデータベースの強みを活かす重要なスキルです。

たとえば、商品テーブルとメーカーテーブルがあり、特定のメーカーが製造した価格が1,000円以上の商品を探す場合などに使います。

SELECT * FROM 商品 INNER JOIN メーカー ON 商品.メーカーID = メーカー.ID WHERE 商品.価格 >= 1000 AND メーカー.名前 = "特定メーカー";

条件式の優先順位とその制御

このセクションでは、複数条件を組み合わせる際の条件式の優先順位とその制御方法について説明します。

この理解は、複雑な条件式を作る上で必須です。

条件式の優先順位

SQLの条件式では、ANDとORが混在している場合、ANDがORよりも優先されます。

「A AND B OR C」では、「(A AND B) OR C」となり、A AND Bが先に実行されるのです。

AとBのAND条件が評価され、その結果かCが真であれば真となります。

数学の四則演算における掛け算と足し算の関係に置き換えて考えましょう。

括弧()を使用した優先順位の制御

優先順位に関わらず、括弧()を使用して優先順位を明示的に制御することをおすすめします。

なぜなら条件式が複雑な場合、優先順位が期待通りに動作しない場合もあるからです。

A AND (B OR C)

BかCが真であれば良い条件となります。

このように括弧を使うことで、より具体的かつ複雑な条件を作成できるでしょう。

まとめ:SQLの複数条件の理解と活用

当記事では、SQLの複数条件の設定と活用方法について学びました。

この記事での学習をさらに深めるためには、実際に手を動かしてSQLを書いてみることが重要です。

以下のような無料リソースを活用し、手を動かしてSQLを身につけていきましょう。

SQL Fiddle - Online SQL Compiler for learning & practice
Discover our free online SQL editor enhanced with AI to chat, explain, and generate code. Support SQL Server, MySQL, Mar...


モバイルバージョンを終了