【笔记】join using&AVG
oracle using
在oracle中,using用于简化连接查询,只有当查询是等值连接和连接中的列必须具有相同的名称与数据类型时,才能使用using关键字进行简化
比如原来是
select s.user_id as user_id ,
sum(s.quantity * p.price) as spending
from Sales s join Product p on s.product_id = p.product_id
group by s.user_id
order by sum(s.quantity * p.price) desc,s.user_id asc
可以写成
select s.user_id as user_id ,
sum(s.quantity * p.price) as spending
from Sales s join Product p USING(product_id)
group by s.user_id
order by sum(s.quantity * p.price) desc,s.user_id asc
avg
对列进行AVG()求平均值时,会自动跳过NULL的行
即如果有'[1],[2],[3],NULL,NULL',得到的平均值是2,而不是1.2
可以使用COALESCE(),其作用就是把NULL值转换为其他值,像是这样用
COALESCE(列名,'0')
这个时候就是1.2了
如果要查询计算最大值比平均值的情况,则可以直接
select a.order_id
from OrdersDetails a
group by a.order_id
HAVING max(a.quantity) >
(select max(avg(b.quantity))
from OrdersDetails b
group by b.order_id)
您能读到这儿,我呢是发自真心的感谢您,若要转载,还望请您带上链接
标签:
Oracle
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现