当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQLServer ntile获取每组前10%的数据

MSSQL
SQL Server数据库技术(14)
SQL Server数据库技术(15)
SQL Server数据库技术(16)
SQL Server数据库技术(17)
SQL Server数据库技术(18)
SQL Server数据库技术(19)
SQL Server数据库技术(20)
SQL Server数据库技术(21)
SQL Server数据库技术(22)
SQL Server数据库技术(23)
SQL Server数据库技术(24)
SQL Server数据库技术(25)
SQL Server数据库技术(26)
SQL Server数据库技术(27)
SQL Server数据库技术(28)
SQL Server数据库技术(30)
SQL Server数据库技术(31)
SQL Server数据库技术(32)
SQL Server数据库技术(34)
SQL Server数据库技术(35)

MSSQL 中的 SQLServer ntile获取每组前10%的数据


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 177 ::
收藏到网摘: n/a

sqlserver2005有关键字ntile(x)和over(partition by.. order by..)子句配合. 比如获取每个表的前10%个字段。
复制代码 代码如下:

select id , name , colid , rn from (
select * , rn = ntile (10 )
over (partition by id order by colorder )
from syscolumns )t where rn = 1