2 dyb2010fly dyb2010fly 于 2013.06.19 09:19 提问

sql语句中的case when then

select case when data.windd in ( '/////', ',,,,,', '-----', '999.9', '',
'null', 'NULL', null ) then ''
when data.windd='' then ''
else convert(decimal(10, 1), data.windd) end windd
from table1

我的本意是如果这个 data.windd 这个字段值是 '/////', ',,,,,', '-----', '999.9', '',
'null', 'NULL', null 其中的一个的话 返回''空字符串,如果不是这几个特殊字符的话转换为数字,现在 一直报 从数据类型 varchar 转换为 numeric 时出错,好像是else语句不管是否满足else条件一直在判断是否能转换。
问怎么写sql能达到我的要求

2个回答

m0_37545767
m0_37545767   2017.09.27 16:13

转换错了吧,CONVERT(data.windd,DECIMAL)

huang931027
huang931027   2017.09.27 16:15

我有一个问题想问题主,为什么要判断 当这个字段的值是 '' 时,又返回 '' 。

 when data.windd='' then ''

这不是浪费资源吗。

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!