#用法说明 select row_number() over(partition by A order by B ) as rowIndex from table A :为分组字段 B:为分组后的排序字段. table 表的结构 多为: 多人 多条的相关数据.(比如:订单信息) 此条sql语句,多用于对数据进行分组排序,并对每个组中的数据分别进行编号,编号从1开始递增,每个组内的编号不会重复: #经典实例 0.填充数据 create table [OrderInfo]( ,) NOT NULL…
听同事分享几种数据库的分页查询,自己感觉,还是需要整理一下MS SqlSever的分页查询的. Sql Sever 2005之前版本: select top 页大小 * from 表名 where id not in ( ) id from 表名 order by id ) order by id 例如: * --10 为页大小 from [TCCLine].[dbo].[CLine_CommonImage] where id not in ( --40是这么计算出来的:10*(5-1) --…
--就在OVER order by 中用case语句进行判断. IF ( OBJECT_ID('tempdb..#TempTable') IS NOT NULL ) DROP TABLE #TempTable SELECT * INTO #TempTable FROM ( SELECT ROW_NUMBER() OVER ( ORDER BY CASE WHEN @orderby ='CreateDate DESC' THEN CreateDate END DESC, CASE WHEN @or…
row_number分页 SELECT TOP 10* --pageSize =10FROM ( SELECT *, row_number () OVER (ORDER BY a.bsqID ASC) AS number FROM TB_RT_BSQDATA a ) AS tableNumberWHERE number > 0*10 --pageIndex = 0, pageSize =10 --先把表中的所有数据都按照一个number进行排序, --然后查询number大于pag…