SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

HRzine Day(エイチアールジン・デイ)は、人が活き会社が成長する人事のWebマガジン「HRzine」が主催するイベントです。毎回、人事の重要課題を1つテーマに設定し、識者やエキスパードが持つ知見・経験を、参加者のみなさんと共有しています。

直近開催のイベントはこちら!

HRzine Day 2024 Winter

2024年2月1日(木)12:00~17:40

主要製品スペック一覧

人事業務の効率・確度・精度を高めるために欠かせないHRテクノロジー。その主な製品の機能を分野ごとに比較できる資料群です。製品検討の参考資料としてご活用ください。

人事労務管理システム<br>主要製品スペック一覧 2023

人事労務管理システム
主要製品スペック一覧 2023

その他のスペック一覧

タレントマネジメントシステム<br>主要製品スペック一覧 2023

タレントマネジメントシステム
主要製品スペック一覧 2023

採用管理システム<br>主要製品スペック一覧 2023

採用管理システム
主要製品スペック一覧 2023

落とし穴はこれで回避! Oracle DB 12c SQL基礎 弱点克服スクール | 第2回

SELECT文の使用によるデータの取得 ~ SQLの基本であるSELECT文は、実は難しかった?!


  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena

意外に「穴」な文字列演算子の問題

今度は、SELECT文において「こんなこともできるのか」という問題に挑戦してみましょう。

問3

emp表のename列は社員の氏名です。次のように表できるSQL文はどれですか?

I'm King.
  • a. SELECT q'[I'm ]'|| ename || '.'
    FROM emp
    WHERE ename = 'KING';
  • b. SELECT q'{I'm }'|| ename || '.'
    FROM emp
    WHERE ename = 'KING';
  • c. SELECT q''I'm ''|| ename || '.'
    FROM emp
    WHERE ename = 'KING';
  • d. SELECT q'ZI'm Z'|| ename || '.'
    FROM emp
    WHERE ename = 'KING';
  • e. SELECT q'(I'm )'|| ename || '.'
    FROM emp
    WHERE ename = 'KING';

正解は、次の実行例のとおり、abcde全部です。実際の試験で、選択肢すべてが正解というのはないと思いますので、それはこの連載だけのお愛嬌だと思ってください。

SQL> -- a
SQL> SELECT q'[I'm ]'|| ename || '.'
  2  FROM emp
  3  WHERE ename = 'KING';

Q'[I'M]'||ENAME
---------------
I'm KING..

SQL> -- b
SQL> SELECT q'{I'm }'|| ename || '.'
  2  FROM emp
  3  WHERE ename = 'KING';

Q'{I'M}'||ENAME
---------------
I'm KING.

SQL> -- c
SQL> SELECT q''I'm ''|| ename || '.'
  2  FROM emp
  3  WHERE ename = 'KING';

Q''I'M''||ENAME
---------------
I'm KING.

SQL> -- d
SQL> SELECT q'ZI'm Z'|| ename || '.'
  2  FROM emp
  3  WHERE ename = 'KING';

Q'ZI'MZ'||ENAME
---------------
I'm KING.

SQL> -- e
SQL> SELECT q'(I'm )'|| ename || '.'
  2  FROM emp
  3  WHERE ename = 'KING';

Q'(I'M)'||ENAME
---------------
I'm KING.

通常、シングルクォーテーション(')で囲むと、文字リテラルまたは日付リテラルとみなされます。 今回のように「このシングルクォーテーションは、リテラル(定数)を囲むためのものではなく、値として扱いたいんだよ!」という場合には、次のようにエスケープシーケンスとして、シングルクォーテーションを追加します。これにより、エスケープシーケンスの後ろにあるシングルクォーテーションは、リテラルとみなされます。

SQL> SELECT 'I''m '|| ename || '.'
  2  FROM emp
  3  WHERE ename = 'KING';

'I''M'||ENAME||
---------------
I'm KING.

でも、後からこのSQL文をメンテナンスする人の立場に立つと、読みづらくないですか? そこで代替え引用符(q)演算子を使うというのが、先ほどの出題で問うていることです。

qの後ろの[]の間にあるものをすべてリテラルとして扱います。 リテラルの範囲を示すものには、[]以外に、{}()<>などの対の記号やシングルバイト文字を使用することもできます。 選択肢dのように「Z」という文字列を使うとわかりづらいでしょうから、他の選択肢のように対の記号を使用するのが、実務的には良いでしょうね。

では、今回は次で終わりにしましょう。

問4

次のSQL文の結果として正しいものを選びなさい。

SELECT ename FROM emp
WHERE UPPER(ename) BETWEEN 'A' AND 'B';
  • a. ADAMS、ALLEN、BLAKEは表示されるが、CLARKは表示されない。
  • b. ADAMS、ALLEN、CLARKは表示されるが、BLAKEは表示されない。
  • c. ADAMS、ALLENは表示されるが、BLAKE、CLARKは表示されない。
  • d. だれも表示されない

次の実行例のとおり、正解はcです。

SQL> SELECT ename FROM emp
  2  WHERE UPPER(ename) BETWEEN 'A' AND 'B';

ENAME
----------
ALLEN
ADAMS

学生時代に学ぶ内容は少しずつ変わっており、最近は、2進数や16進数も習わないとか忘れたとか。 文字コードなんていっても「ふ〜ん」だと思います。

「名前(ename)は1文字じゃないでしょ? 1文字以上の文字列なのに、AだけとかBだけとか範囲にはいらないでしょう?」と悩んだ方も多いと思います。 UPPER(ename) BETWEEN 'A' AND 'B'は、enameAで始まれば何文字以上でも範囲に含まれますが、Bで始まる名前はB1文字なら範囲内ですが、Bで始まる複数の文字は該当しません。

ここでは、文字コード云々という話はしませんので、気になる方は、なぜ、選択肢cが正解なのか、身近な先輩に尋ねてみてください。

この記事は参考になりましたか?

  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena
めざせオラクルマスターホルダー! Oracle DB 12c SQL基礎 弱点克服スクール連載記事一覧

もっと読む

この記事の著者

林 優子(ハヤシ ユウコ)

日本オラクル株式会社の教育ビジネスのスタートアップを全面的に支援し、バージョン5の頃からOracleに携わるベテラン講師として知る人も多い。Oracle認定講師を表彰するExcellent Instructorを連続受賞。1ランク上のITスペシャリスト育成を目標に、データベース分野にとどまらず「プレゼンテーション」、「ロジカルシンキング」などのトレーニングも手がけている。著書に『オラクルマスター教科書』シリーズ(翔泳社)、『プロとしてのデータモデリング入門』(SBクリエイティブ)など。その他、雑誌執筆、著書・メディア出演も多数。

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事をシェア

  • Facebook
  • Twitter
  • Pocket
  • note
  • hatena
HRzine
https://hrzine.jp/article/detail/40 2016/09/12 19:11

Special Contents

AD

Job Board

AD

おすすめ

アクセスランキング

アクセスランキング

イベント

HRzine Day(エイチアールジン・デイ)は、人が活き会社が成長する人事のWebマガジン「HRzine」が主催するイベントです。毎回、人事の重要課題を1つテーマに設定し、識者やエキスパードが持つ知見・経験を、参加者のみなさんと共有しています。

2024年2月1日(木)12:00~17:40

イベントカレンダーを見る

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング