総視聴再生時間43万分以上(2017年5月13日現在)の動画で基本情報技術者試験の過去問&キーワード解説!スキマ時間に動画!〜これじょIT〜

PR広告

平成27年度春 基本情報技術者試験 午後 問3 データベース 設問2

問3 データベース

自治会員の情報を管理する関係データベースの設計及び運用に関する次の記述を読んで、設問1~4に答えよ。

 X地区の自治会では、世帯数の増加と、個人情報管理の厳格化を背景に、手書きの帳票で管理していた自治会員の情報を電子化することにした。この自治会には、236世帯、667人が登録されていて、各世帯は1~8班のいずれかに所属している。

 従来は図1に示すとおり、世帯ごとに、世帯主氏名、住所、電話番号、登録日、所属する班、同居者氏名、続柄、性別、生年月日などの情報を管理していた。

平成27年度春 基本情報技術者試験 午後 問3 データベース 図1

 図1の帳票を基に、図2に示す表構成をもつ関係データベースを作成した。下線付きの項目は、主キーを表す。

〔表の説明〕

  • 世帯表の世帯番号には、各世帯に一意に割り当てた番号が格納されている。
  • 世帯表の世帯主番号には、世帯主の会員番号が格納されている。
  • 会員表の会員番号には、各会員に一意に割り当てた番号が格納されている。
  • 会員表の世帯番号には、会員が属する世帯の世帯番号が格納されている。

設問2

地区の福祉委員会から、1940年よりも前に生まれた会員が含まれる世帯の世帯番号について、情報提供を求められた。該当する世帯番号を抽出する正しいSQL文を解答群の中から選べ。

 なお、同じ世帯番号は一つだけ抽出する。

解答群

  • ア : SELECT DISTINCT 世帯番号 FROM 会員表 WHERE 会員表.生年月日 >= 19400101
  • イ : SELECT 世帯番号 FROM 会員表 WHERE 会員表.生年月日 >= 19391231
  • ウ : SELECT 世帯番号 FROM 会員表 WHERE 会員表.生年月日 < 19400101 GROUP BY 世帯番号
  • エ : SELECT 世帯番号 FROM 会員表 WHERE 会員表.生年月日 <= 19391231 GROUP BY 世帯番号, 会員番号

解説

導きだすのは「1940年よりも前に生まれた会員が含まれる世帯の世帯番号」のデータです。まずはWHERE句に注目しましょう!

  • ア : WHERE 会員表.生年月日 >= 19400101 /* 1940年01月01日以降(当日を含む)のデータなので× */
  • イ : WHERE 会員表.生年月日 >= 19391231 /* 1939年12月31日以降(当日を含む)のデータなので× */
  • ウ : WHERE 会員表.生年月日 < 19400101 GROUP BY 世帯番号 /* 1940年01月01日以前(当日を含まない)のデータなので該当 */
  • エ : WHERE 会員表.生年月日 <= 19391231 GROUP BY 世帯番号, 会員番号 /* 1939年12月31日以前(当日を含む)のデータなので該当 */

可能性があるのは、「ウ」か「エ」となります。欲しいデータは「世帯番号」ですが、「ウ」と「エ」共に、このままだと会員が同じ世帯に属し手いる場合、重複して取得されます。DISTINCTかGROUP BYで重複をなくします。

「エ」の場合、「GROUP BY 世帯番号, 会員番号」とすると、世帯番号ごとの会員番号を取るので、結果的に会員番号まで取得でき重複を削除できません。

「ウ」のように、「GROUP BY 世帯番号」とすることで、世帯番号だけを取得することが可能です!

平成27年度春 基本情報技術者試験午後 問3 データベース 目次

  1. 問題文とキーワード
  2. 設問1
  3. 設問2
  4. 設問3
  5. 設問4

一覧に戻る

タグ: ,,,

PR広告

フェイスブックコメント

平成28年度秋 基本情報技術者試験 午後 テキスト・動画解説

平成28年度秋 基本情報技術者試験 午前 テキスト・動画解説

平成28年度春 基本情報技術者試験 午後 テキスト・動画解説

平成28年度春 基本情報技術者試験 午前 テキスト・動画解説

平成27年度秋 基本情報技術者試験 午後 テキスト・動画解説

平成27年度春 基本情報技術者試験 午後 テキスト・動画解説

平成27年度春 基本情報技術者試験 午前 テキスト・動画解説

平成26年度秋 基本情報技術者試験 午前 テキスト・動画解説

平成26年度春 基本情報技術者試験 午前 テキスト・動画解説