「開発を始めたばかりでも経験豊富な開発者でも、型変換に遭遇するでしょう。型変換とは、値または式をあるデータ型から互換性のある別のデータ型に変換するプロセスを指します。
この投稿では、SQL Server で cast() 関数を使用して、値または式をある型から別の型に変換する方法について説明します。」
SQL Server キャスト関数
次のスニペットは、cast() 関数の構文を示しています。
キャスト ( 表現 なので データ・タイプ [ ( 長さ ) ] )
この関数は、次のパラメーターを受け入れます。
- 式 – 任意の有効な式。
- data_type – ターゲットのデータ型を設定します。
- length – ターゲット データ型の長さとして定義されたオプションの整数値 (サポートされている型のみ)。
関数は、ターゲットの data_type に変換された式を返します。
例を使用して、キャスト関数の使用方法を説明しましょう。
キャスト関数を使用して文字列を整数に変換する
次の例では、cast 関数を使用して、入力文字列を整数値に変換します。
選択する
キャスト ( '100' なので INT ) なので 出力値;
結果の出力:
出力値 | |------------+
100 | |
Cast 関数を使用して Decimal を Int に変換する
次の 2 番目の例では、cast 関数を使用して、10 進数型を int に変換しています。
選択するキャスト ( 3.14159 なので INT ) なので 出力値;
次のように、キャスト関数は入力の小数を最も近い整数値に丸めます。
出力値 | |------------+
3 | |
キャスト関数を使用して文字列を日時に変換する
キャスト関数を使用して、特定の入力文字列を日時値に変換することもできます。以下に例を示します。
選択するキャスト ( 「2022-10-10」 なので 日付時刻 ) なので 出力値;
結果の出力:
出力値 | |-----------------------+
2022年 - 10 - 10 00:00: 00,000 | |
テーブル列でキャスト関数を使用する
特定の列にキャスト関数を適用して、その列の行を別のデータ型に変換することもできます。
たとえば、テーブルがあるとします。
次のように、size_on_disk 列の値を整数に変換できます。
選択するサーバー名 、
キャスト ( size_on_disk なので INT ) なので appx_size
から
エントリ;
結果のテーブルは次のとおりです。
ご覧のとおり、結果の出力は整数値 (四捨五入) として表されます。
注: さまざまな変換タイプがあることに注意してください。
- 暗黙的な変換 – SQL Server エンジンは、要求された操作に最適な変換操作を自動的に適用します。
- 明示的な変換 – cast() や convert() などの変換関数を呼び出して、ユーザーが手動で実行します。
次の表は、変換できる型、適用される変換の型などを示しています。
ソース: マイクロソフト
ゼロイン
このチュートリアルをお読みいただきありがとうございます。このガイドから何か新しいことを学んでいただけたと思います。