SQL2008 CASE WHEN THEN 提示varchar 值转换成数据类型 int 时失败。

table1中字段column1(varchar)中有001和ID001两种值,用CASEWHENTHEN语句查询001显示省内,ID001显示省外,执行语句时提示var... table1中字段column1(varchar)中有001和ID001两种值,用CASE WHEN THEN语句查询001显示省内,ID001显示省外,执行语句时提示varchar值转换成数据类型 int 时失败。求老鸟看看~在线等 展开
 我来答
wyd52x
2016-09-14 · TA获得超过1943个赞
知道小有建树答主
回答量:520
采纳率:0%
帮助的人:635万
展开全部
能否把sql粘贴出来?

个人以为是写Case When的时候 数据类型没对

譬如:
Select Case When column1 =001 Then '省内' When column1 ='D001' Then '省外' End
From table1

这样写是错误的,当他匹配column1 =001的时候 因为001没加引号,会被认为是数字,所以 sql 会把column1 自动转换成数字来与之相比较,如果column1 里面不尽是数字,那么就会出现你说的这种情况,转换int失败。

具体的,得看你sql怎么写的
追问

代码是这样的

追答

果然就是我所说的错误示例....把001 成'001' 

Select Case DM When '001' Then '省内' When 'ID001' Then '省外' End From [SNW]

 不管是条件筛选,还是case when 匹配 数据类型都要一致,不然当时通过了,以后总可能会有问题的

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式