SQL 语句技巧--排名函数的使用实例

   今天看到一篇文章,关于讨论如何优化语句,原文如下:

       作者总结贴: http://blog.csdn.net/wangd1121/archive/2008/06/23/2579435.aspx

       网友讨论贴: http://topic.csdn.net/u/20080504/14/5c5866c3-8b91-45ef-ab17-f994f88f8e42.html 

 

   问题描述:

比如,假设我们有下面这样结构的一张表,这张表的数据量非常巨大。
CREATE TABLE table1(
    
[ID] [bigint] IDENTITY(1,1NOT NULL,
    
[Name] [nvarchar](128NOT NULL,
    
[class] int not null,
    
[date] datetime not null
)
  class表示分类编号。 分类数不固定,至少有上千种分类,date 表示该条记录被更新的时间 

  要求: 我们现在想获得每个分类最新被更新的5条记录。

 

   解决的SQL语句:

select id,name,class,date from(
select id,name,class,date ,row_number() over(partition by class order by date desc)
as rowindex from table1) a
where rowindex <= 5

 

   的确是一个很好的解决办法。

      注意:OVER 子句中的 PARTITION BY 将结果集分为多个分区,这里的partition by class是按照类型分区,当然是有多少个类型分多少个区。

 

    当然作者讨论没有涉及到后续的性能优化讨论,因为表的数据量比较大情况下,如何优化该查询。如果不建立任何索引和处理,以上的执行语句是全表扫描,速度很慢的。

   由于没有上面的数据量,我们从另一个表中模拟这个实现:

    表[zping.com]大约有数据70多万数据,有字段id,operator,operatedate,remark等字段信息,其中operator有两三百个不同值,和上面的执行意义一样:

select * from 
(
select operator , operatedate,row_number() over 
(partition 
by operator order by operatedate ) rn 
from  dbo.[zping.com]
) t
where rn<=5

 

  如果没有建立索引,上述查询速度很慢,这时要如果在operator和operatedate分别建立索引也很慢,建立(operatedate,operator)索引也比较慢,因为要排序,这时建立复合索引(operator,operatedate).

  

   

转载于:https://www.cnblogs.com/zping/archive/2008/09/25/1281832.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/549569.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二项式公式

取 即得 转载于:https://www.cnblogs.com/zeenzhou/p/11462928.html

For in 详解

Delphi 2006 (For In語句) 詳解在Delphi 2005就已經加入了For element in collection do statement語法&#xff0c;可以用來歷遍一個集合、數組等等,下面這個是For in 支持的類型: # Classes.TList # Classes.TCollection # Classes.TStrings # Classes.TInterfaceList # Cla…

代码示例_陀螺仪_SPI

陀螺仪_SPI 基于内核spi驱动修改移植 1 /*2 * Simple synchronous userspace interface to SPI devices3 *4 * Copyright (C) 2006 SWAPP5 * Andrea Paterniani <a.paternianiswapp-eng.it>6 * Copyright (C) 2007 David Brownell (simplification, cleanup)7 *…

tomcat 部署 React 项目后,浏览器刷新报404问题

问题&#xff1a;tomcat部署了react前端项目&#xff0c;可以正常访问&#xff0c;但是页面刷新就报404 一、问题截图 二、解决办法 在tomcat 配置文件web.xml中配置如下代码&#xff1a; web.xml 路径&#xff1a; apache-tomcat-8.5\conf\web.xml <error-page><erro…

美国国家地理

美国国家地理图 (19) National Geographic, 夏威夷 上帝的花园, Hawaii, 19 garden-of-the-gods-90667-lw.jpg (148.7 KB)2008-7-9 09:27 AM上帝的花园 Garden of the Gods, Hawaii, 1996National Geographic Photo Of the DayPhotograph by Jim RichardsonA time-exposed phot…

windows下安装elasticsearch-6.4.3和elasticsearch-head插件

windows下安装elasticsearch-6.4.3和elasticsearch-head插件 博客分类&#xff1a; elasticsearches ElasticSearch下载地址&#xff1a;https://www.elastic.co/cn/downloads/elasticsearch 1.配置elasticsearch 修改一下es使用的参数。编辑config/elasticsearch.yml&#xff…

解决我的windows不是正版的方法?

答&#xff1a;打开注册表。在运行输入REGEDIT&#xff0c;就进入注册表 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon\Notify\WgaLogon&#xff0c; 删除WgaLogon 重新启动 wgatray.exe就不会自动启动了&#xff0c; 再找到你装系统的那个盘比如…

CentOS 5.2 安装Apache服务器后无法访问解决方法

很大的原因是防火墙&#xff1a;通过/etc/init.d/iptables status命令查询是否有打开80端口&#xff0c;如果没有可通过两种方式处理&#xff1a;1.修改vi /etc/sysconfig/iptables命令添加使防火墙开放80端口-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dpo…

es 6.4.3 版本的es的处理方式

https://blog.csdn.net/weixin_44615156/article/details/86701255 转载于:https://www.cnblogs.com/zeenzhou/p/11470725.html

微软独立虚拟机Hyper-V Server 2008

微软9月底如约发布了独立虚拟机操作系统Hyper-V Server 2008&#xff0c;并提供免费下载和使用&#xff0c;用户无需支付40美元即可获得来自微软的虚拟化方案。与之前集成在Windows Server 2008里的Hyper-V模块/插件不同&#xff0c;Hyper-V Server 2008是一个独立的服务器操作…

zookeeper 启动和停止脚本

启动 sh zkServer.sh start 停止脚本 sh zkServer.sh stop 转载于:https://www.cnblogs.com/zeenzhou/p/11474611.html

js的正则处理

1.search()方法&#xff0c;返回首次出现位置&#xff0c;如果找不到匹配则返回-1<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> …

ZooKeeper 相关知识

版权声明&#xff1a;本文为博主原创文章&#xff0c;遵循 CC 4.0 BY-SA 版权协议&#xff0c;转载请附上原文出处链接和本声明。本文链接&#xff1a;https://blog.csdn.net/zhang123456456/article/details/78243658一、zkServer.sh 1、查看 zkServer.sh 帮助信息[rootbigdat…

办公自动化及工作流技术

办公自动化及工作流技术转载于:https://blog.51cto.com/hnoas/105574

启动 elasticsearch

nohup sh elasticsearch & 转载于:https://www.cnblogs.com/zeenzhou/p/11474734.html

CGI 简单的python显示的页面

简介 python 进行服务器的页面的显示 cgi common gateway interface 公用网关接口 简单操作 python3 -m http.server --cgi 8001新建一个cgi-bin目录里面存入一个 py文件#!/usr/bin/env python #codingutf-8 import cgi header Content-Type: text/html\n\nformhtml <HTML…

[ASP.NET 控件实作 Day12] 继承 TBActiveX 重新改写 TBMediaPlayer 控件

上篇介绍的 TBActiveX 控件&#xff0c;它可以支持网页 Media Player 的设定&#xff0c;这跟前面提及的 TBMediaPlayer 功能相同。TBActiveX 具有网页设定 ActiveX 通用属性&#xff0c;所以 TBMediaPlayer 基本上是可以由 TBActiveX 继承下来&#xff0c;再加入 Media Player…

ARM_控制器

ARM_控制器 1.GPIO 控制器&#xff1a;&#xff08;gpio口的通用函数接口定义在gpiolib.c文件中&#xff0c;声明则在gpio.h中&#xff09; linux-3.10\include\linux\gpio.h linux-3.10\drivers\gpio\gpiolib.c API&#xff1a; 1. 申请/获取gpio口的使用权    static in…

这几天惨遭Delphi类型转换折磨,请问怎么把double转成int类型

这几天惨遭Delphi类型转换折磨&#xff0c;请问怎么把double转成int类型 Delphi / Windows SDK/APIhttp://www.delphi2007.net/DelphiBase/html/delphi_20061216093950141.html好不容易找了个FloatToDecimal函数&#xff0c;摆置了半天也不知道怎么个用法&#xff0c;真郁闷。 …

于elasticsearch-rest-high-level-client 操作 Es

安装Java&#xff1a;要求JDK为1.8及以上版本。创建阿里云Elasticsearch实例&#xff1a;实例版本要求大于等于elasticsearch-rest-high-level-client的版本。本文创建一个6.3.2版本的实例。 注意 High Level Client能够向上兼容&#xff0c;例如6.3.2版本的elasticsearch-rest…