でCASTを使用しているとき、私は私がやろうとしていますどのような次データ変換エラーCASE文
declare
@completeCommand nvarchar (max) = 'x'
,@paramVal nvarchar (100)
,@paramName nvarchar (100)
,@paramType nvarchar (100)
,@tempParam sql_variant
declare @parameterList table (
RowID int identity (1,1)
,ParameterValue nvarchar (100)
,ParameterName nvarchar (100)
,ParameterType nvarchar (100)
)
insert into @parameterList
values
('10', 'Param1', 'int')
,('test', 'Param2', 'nvarchar')
-- Process each parameter one at a time
declare ParameterCursor cursor fast_forward for
select ParameterValue, ParameterName, ParameterType
from @parameterList
order by RowID
open ParameterCursor
fetch next from ParameterCursor into @paramVal, @paramName, @paramType
if @@FETCH_STATUS = 0
set @completeCommand = @completeCommand + ' '
while @@FETCH_STATUS = 0
begin
print @completeCommand
-- verify the datatype is correct
set @tempParam = case @paramType
when 'int' then CAST (@paramVal as int)
when 'float' then CAST (@paramVal as float)
when 'nvarchar' then CAST (@paramVal as nvarchar)
else 'NULL'
end
set @completeCommand = @completeCommand + @paramName + ' = ' + @paramVal + ','
fetch next from ParameterCursor into @paramVal, @paramName, @paramType
end
close ParameterCurosr
deallocate ParameterCursor
を実行すると、そのユーザーがデータを入力した検証が「フロートするデータ型はnvarcharを変換エラー」エラーを取得していますデータがコマンド文字列に追加される前に期待されるデータ型と一致します。なぜ上記のコードが失敗するかについてのフィードバックは非常に高く評価されます。
乾杯、 ジョー
基本的な欠陥 - データ型のユーザー入力に依存しています。私が「NVARCHAR」としてデータにタグ付けしているからといって、それはそれを意味するものではありません。ISNUMERICを使用して数値データ型にキャストする前に確認することを検討する必要があります。 –
それは本当かもしれません。しかし、それはcase文が正しいWHEN句を選択しなかった理由を説明していません。 –
ISNUMERICは "IsAllDigits"関数ではないので注意してください。この記事を見てください(サイトに必要な無料登録):http://www.sqlservercentral.com/articles/IsNumeric/71512/ – Tony