SQL问题 求2个字段的百分比

selectTOP(100)PERCENTdbo.vitem.Iid,COUNT(dbo.vote_c.Iid)ASnumcast(100*(caseCOUNT(dbo.... select TOP (100) PERCENT dbo.vitem.Iid, COUNT(dbo.vote_c.Iid) AS num

cast(100*(case COUNT(dbo.vote_c.Iid) when 'a' then 1 else 0 end)/COUNT(dbo.vitem.Vid) as p)+'%' as percentage

FROM dbo.vitem INNER JOIN
dbo.vote_c ON dbo.vitem.Iid = dbo.vote_c.Iid
WHERE (dbo.vitem.flag = 0) AND (dbo.vote_c.flag = 0)
GROUP BY dbo.vitem.Iid, dbo.vitem.Itemtext, dbo.vitem.Vid

--Iid 是投票人的Id ,vid是投票的编号

我想要的是投票人/投票总数 显示百分比 报错是 cast附近有语法错误 希望各位帮忙看看,谢谢
展开
 我来答
MuCloudLi
2010-02-03 · TA获得超过480个赞
知道小有建树答主
回答量:802
采纳率:0%
帮助的人:737万
展开全部
select TOP (100) PERCENT dbo.vitem.Iid, COUNT(dbo.vote_c.Iid) AS num

cast(100*(case COUNT(dbo.vote_c.Iid) when 'a' then 1 else 0 end)/COUNT(dbo.vitem.Vid) as varchar(10))+'%' as percentage

FROM dbo.vitem INNER JOIN
dbo.vote_c ON dbo.vitem.Iid = dbo.vote_c.Iid
WHERE (dbo.vitem.flag = 0) AND (dbo.vote_c.flag = 0)
GROUP BY dbo.vitem.Iid, dbo.vitem.Itemtext, dbo.vitem.Vid
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
tj_angela
2010-02-03 · TA获得超过7529个赞
知道大有可为答主
回答量:6797
采纳率:75%
帮助的人:2529万
展开全部
case COUNT(dbo.vote_c.Iid) when 'a' then 1 else 0 end

'a'和1类型不同,当然不行啊

COUNT(dbo.vote_c.Iid)怎么会去和字符串比
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
KarasCanvas
2010-02-03 · TA获得超过2865个赞
知道大有可为答主
回答量:3619
采纳率:0%
帮助的人:3241万
展开全部
cast(表达式 as 数据类型)
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式