sql语句查询入门问题

select[branch-name],avg(balance)fromAccountgroupby[branch-name]havingavg(balance)>500... select [branch-name],avg(balance)
from Account
group by [branch-name]
having avg(balance)>500

上面这句正确,可是在末尾加上:

order by balance asc

后就不正确了
展开
 我来答
数据库强者
2007-12-01 · TA获得超过525个赞
知道答主
回答量:329
采纳率:0%
帮助的人:0
展开全部
看清楚了!

avg(balance) :这个地方没有别名,所以sql找不到balance

你可以帮他添加一个别名

avg(balance) as balance

你试试看
select [branch-name],avg(balance) as balance
from Account
group by [branch-name]
having avg(balance)>500
order by balance asc
有问题请告知!
snowue
2007-12-01 · TA获得超过262个赞
知道小有建树答主
回答量:340
采纳率:33%
帮助的人:105万
展开全部
当你在sql语句中用了含有group by 关键字时,后面的要再使用order by 关键字时,排序的列必须是显示出来的列,也就是在select 后面要能找得到的列。

你可以这样试下:
select [branch-name],avg(balance),balance
from Account
group by [branch-name]
having avg(balance)>500
order by balance asc
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
85718779
2007-12-01 · 超过37用户采纳过TA的回答
知道小有建树答主
回答量:128
采纳率:0%
帮助的人:32.7万
展开全部
我想数据库强者的 答案是正确的。balance是一个汇总的值,不能进行Order的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式