基本情報技術者試験の過去問と解説
[TOP] [午前分野別] [午後分野別] [キーワード索引] [令和元年秋午前] [令和元年秋午後]

平成27年 春期 基本情報技術者 午後 問03
問03   4問選択

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

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

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


図1 世帯情報を管理していた帳票と記入例

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


図2 表構成とデータ格納例

〔表の説明〕

(1) 世帯表の世帯番号には,各世帯に一意に割り当てた番号が格納されている。

(2) 世帯表の世帯主番号には,世帯主の会員番号が格納されている。

(3) 会員表の会員番号には,各会員に一意に割り当てた番号が格納されている。

(4) 会員表の世帯番号には,会員が属する世帯の世帯番号が格納されている。

設問1 図2の表構成を完成するまでの設計について, 次の記述中の に入れる適切な答えを,解答群の中から選べ。

 図1の帳票は非正規形なので,まず, 世帯情報を 取り出して会員表を作成した。次に, 続柄表と性別表を作成した。 続柄表と性別表のレコード件数は少ないが,例えば,帳票の記載で“男”と“男性”の ように同じ意味を表すデータに対する定義の一意性を保証できる効果がある。

解答群

ア 障害回復のために       イ 第1正規化に基づいて       ウ 第2正規化に基づいて

エ 第3正規化に基づいて       オ 排他制御のために

解答 a ←クリックすると正解が表示されます

解答 b ←クリックすると正解が表示されます

基本情報技術者試験


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

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

解答群

ア SELECT DISTINCT 世帯番号 FROM 会員表 WHERE 会員表.生年月日 >= 194ØØ1Ø1

イ SELECT 世帯番号 FROM 会員表 WHERE 会員表.生年月日 >= 19391231

ウ SELECT 世帯番号 FROM 会員表 WHERE 会員表.生年月日 < 194ØØ1Ø1
                   GROUP BY 世帯番号

エ SELECT 世帯番号 FROM 会員表 WHERE 会員表.生年月日 <= 19391231
                   GROUP BY 世帯番号,会員番号

解答 ←クリックすると正解が表示されます

基本情報技術者試験


設問3 班ごとの会員数に偏りがあるとの意見が挙がったので,班の再編を 検討することになった。現在の状況を確認するために,班ごとの世帯数と会員数を集計する。 次の SQL 文の に入れる正しい答えを,解答群の中から選べ。 SELECT 世帯表.班,
  FROM 世帯表,会員表
  WHERE 世帯表.世帯番号 = 会員表.世帯番号
  GROUP BY 世帯表.班
解答群 ア COUNT(*),COUNT(会員表.会員番号)

イ COUNT(*),MAX(会員表.会員番号)

ウ COUNT(DISTINCT 世帯表.世帯番号),COUNT(*)

エ COUNT(世帯表.世帯番号),MAX(会員表.会員番号)

解答 c ←クリックすると正解が表示されます

基本情報技術者試験


設問4 地区の子供会役員から,子供会に所属する子供の情報を照会できるようにして ほしいとの要望が挙がったので,図3に示すビューを作成することにした。子供会には, 生年月日が 20030402 〜 20090401 の会員が所属する。次の SQL 文の に入れる正しい答えを,解答群の中から選べ。

解答群

ア 会員表.会員番号 = ANY(SELECT会員表.会員番号 FROM 会員表
              WHERE 会員表.生年月日 IN(2ØØ3Ø4Ø2,2ØØ9Ø4Ø1))

イ 会員表.会員番号 = 世帯表.世帯主番号 AND
  会員表.生年月日 BETWEEN 2ØØ3Ø4Ø2 AND 2ØØ9Ø4Ø1

ウ 会員表.世帯番号 = ANY(SELECT会員表.世帯番号 FROM 会員表
              WHERE 会員表.生年月日 IN(2ØØ3Ø4Ø2,2ØØ9Ø4Ø1))

エ 会員表.世帯番号 = 世帯表.世帯番号 AND
  会員表.生年月日 BETWEEN 2ØØ3Ø4Ø2 AND 2ØØ9Ø4Ø1

解答 d ←クリックすると正解が表示されます


[←前の問題] [次の問題→] [問題一覧表] [分野別] [基本情報技術者試験TOP ]