如何将varchar转换为numeric

cast(sum(casewhenp.ob_problemstatus='4'then1else0end)*100/casewhencount(*)=0then1else... cast(sum(case when p.ob_problemstatus='4' then 1 else 0 end)*100/case
when count(*)=0 then 1 else count(*) end as char)+'%' psrate 这么写可以但 无法保留小数。

cast(sum(case when p.ob_problemstatus='4' then 1 else 0 end)*100/case
when count(*)=0 then 1 else count(*) end as decimal (18,2) )+'%' psrate 这么写报从数据类型 varchar 转换为 numeric 时出错。
convert(numeric,
(cast(sum(case when p.ob_problemstatus='4' then 1 else 0 end)*100/case
when count(*)=0 then 1 else count(*) end as char ))+'%' psrate 这么写报从数据类型 varchar 转换为 numeric 时出错
我的是sql2005数据库 现在我想保留2位小数 求解
展开
 我来答
luoxuanjin
推荐于2016-05-31 · TA获得超过252个赞
知道小有建树答主
回答量:156
采纳率:0%
帮助的人:174万
展开全部
再套一个类型转换就是了。另外转成char会固定占位,格式难看
给你改成varchar了。
cast(cast(sum(case when p.ob_problemstatus='4' then 1 else 0 end)*100/case
when count(*)=0 then 1 else count(*) end as decimal (18,2) ) as varchar)+'%' psrate
更多追问追答
追问
实在感谢 试了一下啊确实可以 貌似没有进行四舍五入 如果想四舍五入的话 round函数 应该加在什么位置啊? 试了半天都没成功。
追答
cast(round(sum(case when p.ob_problemstatus='4' then 1 else 0 end)*100/case 
when count(*)=0 then 1 else count(*) end,2) as varchar)+'%' psrate
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式