易截截图软件、单文件、免安装、纯绿色、仅160KB

SQL 随机抽样的总结

对于SQL 随机抽样我们常想到的就是newid(),但如果对于一个在百万、千万甚至更大海量数据表中抽样的话,简单的newid(),其性能,效率就不是很理想了。所以在这里有必要讨论一下,择优而用。
 
long_goods是一个百万数据的表,Ctrl+L执行以下语句:
 
--id_index是我为主键加的一个非聚焦索引
SELECT top 1  * from long_goods order by newid()
--查询开销 43%
SELECT top 1  * from long_goods with(index=id_index) order by newid()
--查询开销 54%
select top 1 * from long_goods where id=(select top 1 id from long_goods order by newid())
--查询开销 1%
select top 1 * from long_goods where id=(select top 1 id from long_goods with(index=id_index) order by newid())
--查询开销 1%
 
虽然第三个与第四个的开销是一样,但实际应该是第四种优于第三种。
 
如果MS SQL2005升级到支持 TABLESAMPLE 的话,以下语句的抽样执行效率可为最优的
SELECT * from long_goods TABLESAMPLE SYSTEM (10 PERCENT)
 
呵呵..下班了,至于其中原因,下次有空再续.


相关文档:

在pl/sql 中改变列长度

 
    
 
NO.1  
alter   table   pdt   modify("PDTNAME",varchar2(100))
NO.2  
字段不用“”  
  alter   table   pdt   modify(PDTNAME,varchar2(100)) &n ......

Sql语句学习笔记(1) 创建数据库

说明:创建一个影碟租赁管理系统,这里主要抽象了四张表:
tb_user(用户信息),tb_movie_type(影片类型),tb_movie(影片信息),tb_retal(租赁记录)
use master--系统表,所有创建的数据库均在此被记录
go
--检测是否已经存在RetaDB这个数据库,有的话,不能重名,可以进行删除
if exists (select * from sysdatabas ......

我的SQL之路2

   至今未有成就,甚感彷徨。
   并不是很突然的想学SQL,而是在之前说的那样,在我绕了一大圈之后,才知道自己也是一无所知,枉学了这么多年。
   我一直想脱离学校的教育模式来自学,然而我并不承认学校的教育方式是一无所用的,至少学到的东西是实在的。从学校的角度来考虑, ......

初学PL/SQL的一些基本知识

 1,一个完整的PL/SQL 语句由三个部分组成。
             declare
                   声明部分,定义变量,数据类型,异常,局部子程序等。
 &nb ......

纵表转横表的"SQL"示例:

纵表转横表的"SQL"示例:
  纵表结构:
  
  fname ftype fvalue
  小乔 zaocan 10
  小乔 zhongcan 20
  小乔 wancan 5
  
  转换后的表结构:
  
  fname zaocan_value zhongcan_value wancan_value
  小乔 10 20 5
  
  纵表转横表SQL示例:
  
  select Fname, sum(case ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号