登録部署一覧
配点 : 20点難易度 : 2
制限実行時間 : 1000ms制限メモリ使用量 : 128 MB
SQLiteの注意点

TOPSIC SQLでは、SQLの実行環境にSQLiteを使用しています。SQLite以外のRDBMSの文法を使用することはできません。
問題を解く際に注意すべきSQLiteの制約について、以下に記載してありますのでご確認下さい。

  1. NUMERIC、INTEGER、REALは、自身のクラスへの変換が推奨されていますが、変換できなかった場合でも、そのまま格納されます。
  2. 新しくデータを追加した場合、既に格納されているデータの中で ROWID の値が最大のものを探し、それに1を加えた値が新しく追加されるデータの ROWID の値として保存されます。
  3. 外部結合は、左外部結合を行う LEFT OUTER JOIN 句のみ使用できます。
    ※2022年12月以降、LEFT / RIGHT / FULL OUTER JOIN が使用可能となりました。
  4. 指定した日付と時刻のタイムゾーンはUTCとして扱われます。
  5. 日付関数や文字列関数については、SQLiteで固有の関数があります。
  6. テーブル項目の論理名が「◯◯日」となっている場合は、日付項目の時分秒は設定されていません。論理名が「◯◯日時」となっている場合は、日付項目の時分秒まで設定されています。
    • 「受注日」の場合は「2021-01-01」
    • 「受注日時」の場合は「2021-01-01 15:15:15」

その他のSQLiteの制約については、SQLiteの公式ドキュメントをご確認ください。
また、ER図の読み方やSQLiteの関数および構文などについては、「受験ルール・用語」をご確認ください。

問題

受注テーブル(TBL_ORDERS)と売上テーブル(TBL_SALES)に登録されている部署コード(DEPT_CODE)の一覧を表示しなさい。表示するDEPT_CODEの重複はなしとする。また、DEPT_CODEが部署テーブル(TBL_DEPT)に存在しない場合は、DEPT_CODEのみ表示すること。

表示項目は以下とする。

  • DEPT_CODE
  • DEPT_NAME

表示順

  1. DEPT_CODEの昇順

表示フォーマット

※あくまでフォーマットを示すもので、正解例ではありません。行数も正解とは異なります。

DEPT_CODE DEPT_NAME
10 技術部
20 人事部
30 総務部
40 経理部
50 NULL

ER図 (半角:物理名、全角:論理名)


テーブル定義

テーブル名: TBL_DEPT

主キー 列名 データ型 必須 デフォルト値
✔︎ DEPT_CODE NUMBER ✔︎ NULL
DEPT_NAME VARCHAR NULL

テーブル名: TBL_ORDERS

主キー 列名 データ型 必須 デフォルト値
✔︎ ORDER_NO VARCHAR ✔︎ NULL
ORDER_DATE VARCHAR ✔︎ NULL
DEPT_CODE NUMBER ✔︎ NULL
CUST_CODE NUMBER ✔︎ NULL
ORDER_AMT NUMBER ✔︎ 0

テーブル名: TBL_SALES

主キー 列名 データ型 必須 デフォルト値
✔︎ SALES_NO VARCHAR ✔︎ NULL
SALES_DATE VARCHAR ✔︎ NULL
DEPT_CODE NUMBER ✔︎ NULL
SALES_AMT NUMBER ✔︎ 0

サンプルデータ

テーブル名: TBL_DEPT

DEPT_CODE DEPT_NAME
10 技術部
20 人事部
30 総務部
40 経理部

テーブル名: TBL_ORDERS

ORDER_NO ORDER_DATE DEPT_CODE CUST_CODE ORDER_AMT
D0100 2024-04-01 10 123 10000
D0101 2024-04-02 20 345 3300
D0102 2024-04-03 30 444 45000
D0103 2024-04-04 60 567 27000
D0104 2024-04-05 10 789 33000
D0105 2024-04-06 20 789 11000
D0106 2024-04-07 40 222 34000
D0107 2024-04-08 50 123 22000

テーブル名: TBL_SALES

SALES_NO SALES_DATE DEPT_CODE SALES_AMT
S0001 2024-03-01 10 1000
S0002 2024-03-02 20 1500
S0003 2024-03-03 30 1300
S0004 2024-03-04 40 1200
S0005 2024-03-05 50 2000
S0006 2024-03-06 60 2400
S0007 2024-03-07 70 1800

Sorry, Japanese Only.