メインコンテンツまでスキップ
バージョン: 26.x

REPLACE_EMPTY

説明

REPLACE_EMPTY関数は、文字列内の文字の一部を他の文字に置き換えるために使用されます。REPLACE関数とは異なり、oldが空文字列の場合、new文字列はstr文字列の各文字の前とstr文字列の末尾に挿入されます。

この関数は主にPrestoおよびTrinoとの互換性を保つために使用され、その動作はPrestoおよびTrinoのREPLACE()関数と全く同じです。バージョン2.1.5以降でサポートされています。

構文

REPLACE_EMPTY ( <str>, <old>, <new> )

パラメータ

Parameterデスクリプション
<str>置換対象となる文字列。
<old>置換される部分文字列。<old><str>に含まれていない場合、置換は実行されません。<old>が空文字列の場合、str文字列の各文字の前に<new>文字列が挿入されます。
<new><old>を置換するために使用される新しい部分文字列。

Return Value

部分文字列を置換した後の新しい文字列を返します。特殊なケース:

  • いずれかのParameterがNULLの場合、NULLが返されます。
  • <old>が空文字列の場合、<str>文字列の各文字の前に<new>文字列が挿入された文字列が返されます。

Examples

SELECT replace('hello world', 'world', 'universe');
+---------------------------------------------+
| replace('hello world', 'world', 'universe') |
+---------------------------------------------+
| hello universe |
+---------------------------------------------+
SELECT replace_empty("abc", '', 'xyz');
+---------------------------------+
| replace_empty('abc', '', 'xyz') |
+---------------------------------+
| xyzaxyzbxyzcxyz |
+---------------------------------+
SELECT replace_empty("", "", "xyz");
+------------------------------+
| replace_empty('', '', 'xyz') |
+------------------------------+
| xyz |
+------------------------------+