T-SQL の目標は、整数値と文字列を組み合わせた書式設定された結果を生成することです。 。これは、表示目的でデータを操作するときによく発生します。
ActualWeightDIMS という名前の関数は、重量と寸法を表す数値を 1 つの文字列に連結するように設計されています。ただし、関数の実行時にエラーが発生します。具体的には、「varchar 値 'x' をデータ型 int に変換するときに変換に失敗しました。」
関数が試行したためにエラーが発生します。明示的に文字列に変換せずに、文字列文字を整数値と連結します。 T-SQL では、@Actual_Dims_Lenght などの数値が「x」などの文字列と結合されると、エンジンはそれを算術演算を実行しようとしていると解釈します。
この問題を解決するには、連結前に整数パラメータを文字列に明示的に変換する必要があります。これは、異なるデータ型間で値を変換できる CAST 関数を使用して実現できます。
修正されたコード:
SET @ActualWeightDIMS = CAST(@Actual_Dims_Lenght AS VARCHAR(16)) + 'x' + CAST(@Actual_Dims_Width AS VARCHAR(16)) + 'x' + CAST(@Actual_Dims_Height AS VARCHAR(16))
整数パラメータを文字列にキャストすることで、演算子が正しく実行されるようになりました。文字列の連結を実行し、目的の形式の出力を生成します。
ただし、言及されていませんここで示した特定のケースでは、ユーザーが重量と寸法の両方を入力できないシナリオの処理を検討することをお勧めします。このような状況では、ユーザーに有意義なフィードバックを提供し、潜在的なデータ不整合を防ぐために、適切なエラー処理と検証を実装する必要があります。
以上がT-SQL 文字列連結の「varchar 値 'x' をデータ型 int に変換するときに変換に失敗しました」というエラーを修正する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。