問題ID:19516
- フォーラムは新サイトへ移行しました。
- このフォーラムではゲスト投稿が禁止されています
問題ID:19516
msg# 1
satou1144
投稿数: 1
PRODUCTS表の製品名に「HITS_」と「's」が順番で含まれている行を検索する条件として、正しいものはどれですか(該当するものを全て選択して下さい)。
○ WHERE prod_name LIKE '%HITSW_%''s%' ESCAPE 'W'
○ WHERE prod_name LIKE q'(%HITSW_%'s%)' ESCAPE 'W'
WHERE prod_name LIKE q'(%HITS_%'s%)'
WHERE prod_name LIKE '%HITS_'s%'
WHERE prod_name = q'(%HITSW_%'s%)' ESCAPE 'W'
問題がこのようになっており、正解に○をつけてあります。
ここで疑問なのが、回答の一番上、
WHERE prod_name LIKE '%HITSW_%''s%' ESCAPE 'W'
こちらの、'%HITSW_% ''s%'の部分です。
この場合の一重引用符を二回続けた後に、もう一度「'」を記述するべきだと思ったのですが、いかがでしょうか?
正しくは
'%HITW_%'''s%になるのではないでしょうか?
もし間違いでしたら、申し訳ございません。
○ WHERE prod_name LIKE '%HITSW_%''s%' ESCAPE 'W'
○ WHERE prod_name LIKE q'(%HITSW_%'s%)' ESCAPE 'W'
WHERE prod_name LIKE q'(%HITS_%'s%)'
WHERE prod_name LIKE '%HITS_'s%'
WHERE prod_name = q'(%HITSW_%'s%)' ESCAPE 'W'
問題がこのようになっており、正解に○をつけてあります。
ここで疑問なのが、回答の一番上、
WHERE prod_name LIKE '%HITSW_%''s%' ESCAPE 'W'
こちらの、'%HITSW_% ''s%'の部分です。
この場合の一重引用符を二回続けた後に、もう一度「'」を記述するべきだと思ったのですが、いかがでしょうか?
正しくは
'%HITW_%'''s%になるのではないでしょうか?
もし間違いでしたら、申し訳ございません。
Re: 問題ID:19516
msg# 1.1
quensan
投稿数: 119
一重引用符を2つ続けて記述するのが正しいのですが、なぜもう1つ必要だと思われましたか?
3つだとエラーになりました。
SQL> SELECT prod_name
FROM products
WHERE prod_name LIKE '%HITSW_%'''s%' ESCAPE 'W';
ERROR:
ORA-01756: 引用符付き文字列が正しく終了していません
3つだとエラーになりました。
SQL> SELECT prod_name
FROM products
WHERE prod_name LIKE '%HITSW_%'''s%' ESCAPE 'W';
ERROR:
ORA-01756: 引用符付き文字列が正しく終了していません