- カテゴリ:
TO_CHAR , TO_VARCHAR¶
入力式を文字列に変換します。 NULL 入力の場合、出力は NULLです。
これらの関数は同義語です。
構文¶
引数¶
必須:
expr任意のデータ型の式です。
numeric_expr数値式です。
date_or_time_exprDATE、 TIME、または TIMESTAMP型の式です。
binary_exprBINARY または VARBINARY型の式です。
オプション:
format出力文字列の形式です。
numeric_exprには、数値式の解釈に使用される SQL 形式モデルを指定します。詳細については、 SQL 形式モデル をご参照ください。date_or_time_exprには、文字列を解析または生成するために期待される形式を指定します。詳細については、 変換関数の日付と時刻の形式 をご参照ください。デフォルトは、次のセッションパラメーターの現在の値です。
DATE_OUTPUT_FORMAT ( DATE 入力の場合)
TIME_OUTPUT_FORMAT ( TIME 入力の場合)
TIMESTAMP_OUTPUT_FORMAT ( TIMESTAMP 入力の場合)
binary_exprには、文字列を生成する形式を指定します。(例:「HEX」、「BASE64」または「UTF-8」)。詳細については、 サポートされているバイナリ形式の概要 をご参照ください。
戻り値¶
この関数は VARCHAR データ型の値または NULL を返します。
使用上の注意¶
VARIANT、 ARRAY、または OBJECT 入力の場合、出力は JSON ドキュメントまたは JSON 基本値を含む文字列です(ただし VARIANT または OBJECT に XML タグが含まれている場合、出力はXMLドキュメントを含む文字列です)。
VARIANT に保存された文字列はそのまま保存されます(JSON 文字列に変換されません)。
JSON null 値は、単語「null」を含む文字列に変換されます。
例¶
以下の例では、数値、タイムスタンプ、日付を文字列に変換しています。
数値を変換する例¶
数値を指定された 形式 で文字列に変換します。
出力は、指定された形式に基づいて値がどのように文字列に変換されるかを示しています。
>と<シンボルは、出力に含まれる文字列リテラルです。スペースが挿入されている場所がわかりやすくなります。D2_1列には、数字の前に$のある値が表示されます。3987値の場合は、形式の桁位置よりも数字の整数部分の桁数が多いため、すべての桁が#として出力され、オーバーフローを示します。0.10、0.01、1.111の値の場合は、数値の端数部分の桁数が形式の桁数よりも多いため、端数値は切り捨てられます。
D4_1の列は、ゼロ値が整数部の空白として表現されていることを示しています。0、0.10、0.01の値の場合、セパレーターの前のゼロはスペースで置き換えられます。0.10、0.01、1.111の値の場合は、数値の端数部分の桁数が形式の桁数よりも多いため、端数値は切り捨てられます。
TME列は科学的表記法での値を示しています。TM9列は、数値の値に応じて整数または小数で表示されます。X4列は、小数部を除いた16進数で値を表示します。SX4列は、数値の絶対値を16進数で示し、数値記号(+または-)を含みます。
この例では、対数値を文字列に変換します。
タイムスタンプと日付を変換する例¶
TIMESTAMP 値を指定した形式の文字列に変換します。
DATE 値をデフォルト形式の文字列に変換します。
DATE 値を指定した形式の文字列に変換します。