SQLの基本(その1)

2009年10月13日(火)
藤本 壱

さまざまな条件を指定する

SELECT文でデータを取り出す際には、「

まず、「IN」という演算子があります。IN演算子は、列の値が、値のリストのどれかと一致する行を取り出すときに使います。書き方は次の通りです。
---------------------------------------------------
 フィールド名 IN (値1, 値2, ・・・)
---------------------------------------------------

例えば、address(住所録)のテーブルに、都道府県を表す「pref」という列があるとします。この時に、pref列の値が「東京都」「神奈川県」「千葉県」「埼玉県」のどれかである行の「name」列を取り出したい場合は、SELECT文を次のように書きます。
---------------------------------------------------
SELECT name
FROM address
WHERE pref IN ('東京都', '神奈川県', '千葉県', '埼玉県')
---------------------------------------------------

「LIKE」という演算子もよく使います。LIKE演算子は、列の値の一部に、特定の値を含む行を取り出すときに使います。図3-1のような書き方をします。

例えば、図3-2の上半分のようなaddressテーブルがある時に、address列の先頭が「東京都」である行を取り出し、その「name」列と「address」列を取り出したいとします。この時は、次のようなSELECT文を書きます。
---------------------------------------------------
SELECT name, address
FROM address
WHERE address LIKE '東京都%'
---------------------------------------------------

また、「NOT」という演算子を使うと、条件を否定(逆にする)ことができます。例えば、先ほどのLIKE演算子を使った例を以下のように書き換えると、「address列の先頭が『東京都』」を否定して、「address列の先頭が『東京都』ではない」という条件で行を取り出すことができます。
---------------------------------------------------
SELECT name, address
FROM address
WHERE address NOT LIKE '東京都%'
---------------------------------------------------

行を並べ替える

テーブルから行を取り出す時に、並べ替えを行いたいこともよくあります。例えば、住所録のテーブルから行を取り出す場合だと、名前の五十音順に並べ替えることが多いです。

並べ替えを行うには、SELECT文の最後に「ORDER BY」という句を追加します。「ORDER BY フィールド名」のように書くことで、そのフィールドの値の昇順(値が小さい方から順に並べ替え)で結果を得ることができます。

例えば、図3-3の上半分のようなaddressテーブルがあるときに、男性(「sex」列の値が男)の行を取り出し、「furigana」列の値の昇順で行を並べ替えて、「name」列と「furigana」列を取り出したいとします。この場合のSELECT文は、次のように書きます。
---------------------------------------------------
SELECT name, furigana
FROM address
WHERE sex = '男'
ORDER BY furigana
---------------------------------------------------

昇順だけでなく、降順で並べ替えることもできます。その場合は、ORDER BY句を「ORDER BY フィールド名 DESC」と書きます。

例えば、先ほどのSELECT文を、年齢の高い人から順に並べ替えるように変えるとします。これは、「age」列の降順で並べ替えることに当たりますので、次のようなSELECT文になります。
---------------------------------------------------
SELECT name, furigana
FROM address
WHERE sex = '男'
ORDER BY age DESC
---------------------------------------------------

1つの列をキーにして並べ替えを行う場合、複数の行でその列の値が同じになっていることもあり得ます。例えば、ふりがなで並べ替える場合、同姓同名(=ふりがなが同じ)の人が2人以上いることもあり得ます。

このような時には、ORDER BY句に複数の列を書いて、それらすべてをキーにして並べ替えを行うこともできます。

例えば、先ほどのSELECT文を変えて、まずふりがなの五十音順で並べ替え、同姓同名の人がいたら、年齢の高い人から順に並べ替えたいとします。この場合は、次のように書きます。
---------------------------------------------------
SELECT name, furigana
FROM address
WHERE sex = '男'
ORDER BY furigana, age DESC
---------------------------------------------------

【参考文献】
藤本壱『これだけは知っておきたいデータベースの常識』技術評論社(発行年:2009)

1969年生まれ。神戸大学工学部電子工学科卒。ソフトメーカー勤務後、フリーライターとして独立。現在では、パソコン関係およびマネー関係の書籍を中心に執筆活動を行っている。ブログ「The blog of H.Fujimoto」は、Movable TypeやWordPressの情報を中心に毎日更新している(http://www.h-fj.com/blog/)。

Think ITメルマガ会員登録受付中

Think ITでは、技術情報が詰まったメールマガジン「Think IT Weekly」の配信サービスを提供しています。メルマガ会員登録を済ませれば、メルマガだけでなく、さまざまな限定特典を入手できるようになります。

Think ITメルマガ会員のサービス内容を見る

他にもこの記事が読まれています