SQLの基本(その1)
さまざまな条件を指定する
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)