我正在错误使用CAST时,“错误转换数据类型为nvarchar浮动”运行以下数据转换错误的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”,并不意味着它是。在转换为数字数据类型之前,您应该考虑使用ISNUMERIC进行确认。 – 2011-02-03 21:47:49
这可能是对的。但是这并不能解释为什么案例陈述没有选择正确的WHEN条款。 – 2011-02-03 21:52:50
小心,ISNUMERIC不是“IsAllDigits”函数。看看这篇文章(免费注册到网站需要):http://www.sqlservercentral.com/articles/IsNumeric/71512/ – Tony 2011-02-03 21:53:02