关联查询中使用TOP引起的性能问题分析

类似这样的查询

 

 

select * from (

SELECT TOP 500 IsNULL(j.project_id,-1) AS project_id, p.page_id, p.displayname, 

ROW_NUMBER() OVER(ORDER BY p.displayname) AS RowNum, 

SUM(IsNUll(s.avg_loadtime,0)*1.0*IsNULL(s.pageviews,0))/CASE WHEN SUM(IsNULL(s.pageviews,0))=0 

OR SUM(IsNULL(s.pageviews,0)) IS NULL THEN 1 ELSE SUM(IsNULL(s.pageviews,0)) END AS avg_LoadTime, 

SUM(IsNULL(s.pageviews,0)) AS PageViews, p.flag,p.pagetype 

FROM rum_page p  

LEFT JOIN ( select 

top 500 

RUM_page_stats.page_id, 

IsNULL(CASE WHEN SUM(pageviews)=0 THEN 0 ELSE SUM(avg_loadtime*1.0*pageviews)/SUM(pageviews) END,0) AS avg_loadtime, 

IsNULL(SUM(pageviews),0) AS pageviews  

from RUM_page_stats(nolock) 

where createtime >='2009-09-14 10:51:19'  and RUM_page_stats.account_id=10571 

group by RUM_page_stats.page_id 

order by sum(pageviews) desc 

) s ON p.page_id=s.page_id 

LEFT JOIN ( 

select a.project_id,a.account_id,a.projectname,a.status,b.page_id 

from rum_project(nolock) a INNER JOIN rum_project_page(nolock) b on a.project_id=b.project_id 

where a.account_id=10571 and a.status='active' ) j ON p.page_id=j.page_id 

WHERE p.account_id=10571 AND p.status='active'  and (p.isHide=0 or p.isHide is null)

GROUP BY p.page_id,p.displayname,j.project_id,p.flag,p.pagetype 

ORDER BY pageviews DESC, j.project_id DESC, p.page_id ) final 

order by project_id desc, page_id

 

 

其中标为红色的部分,也就是嵌套内部的“top 500”会导致关联的每一条记录都与嵌套内的记录关联一次,从而大幅影响性能。

而从语法上看,此“top 500”加与不加对结果并无影响。

在当今数字化教育蓬勃发展的背景下,校园网络作为教学与科研的关键基础设施,其重要性日益凸显。本文旨在探讨小型校园网络的规划与设计,以满足网络实验教学的需求,为相关专业师生提供一个高效、稳定且功能完备的网络实验环境,助力教学活动顺利开展,提升学生的实践能力和创新思维。 网络实验教学要求校园网络具备高度的灵活性与可扩展性。学生需在实验过程中模拟各种网络拓扑结构、配置不同网络设备参数,这就要求网络能够快速调整资源分配,适应多样化的实验场景。同时,为保证实验数据的准确性和实验过程的稳定性,网络的高可靠性与低延迟特性不可或缺。此外,考虑到校园内多用户同时接入的场景,网络还需具备良好的并发处理能力,确保每位用户都能流畅地进行实验操作。 采用层次化结构构建小型校园网络,分为核心层、汇聚层与接入层。核心层选用高性能交换机,负责高速数据转发与关键路由决策,保障网络主干的稳定运行;汇聚层连接不同教学区域,实现数据的汇聚与初步处理,通过划分虚拟局域网(VLAN)对不同专业或班级的实验流量进行隔离,避免相互干扰;接入层则直接连接学生终端设备,提供充足的接入端口,满足大量用户同时接入的需求,并通过端口安全策略限制非法设备接入,保障网络安全。 在设备选型上,核心层交换机需具备高吞吐量、低延迟以及丰富的路由协议支持能力,以满足复杂网络流量的转发需求;汇聚层交换机则注重VLAN划分与管理功能,以及对链路聚合的支持,提升网络的可靠性和带宽利用率;接入层交换机则需具备高密度端口、灵活的端口配置以及完善的用户认证功能。配置方面,通过静态路由与动态路由协议相结合的方式,确保网络路径的最优选择;在汇聚层与接入层设备上启用VLAN Trunk技术,实现不同VLAN间的数据交换;同时,利用网络管理软件对设备进行集中监控与管理,实时掌握网络运行状态,及时发现并解决潜在问题。 网络安全是校园网络规划的关键环节。在接入层设置严
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值