用一句SQL取出第 m 条到第 n 条记录的方法

1 --从Table 表中取出第 m 条到第 n 条的记录:(Not In 版本)

3 SELECT TOP n-m+1 * 
4 FROM Table 
5 WHERE (id NOT IN (SELECT TOP m-1 id FROM Table ))  


8 --从TABLE表中取出第m到n条记录 (Exists版本)

10 SELECT TOP n-m+1 * FROM TABLE AS a WHERE Not Exists
11 (Select * From (Select Top m-1 * From TABLE order by id) b Where b.id=a.id ) 
12 Order by id
13 
14 
15 --m为上标,n为下标,例如取出第8到12条记录,m=8,n=12,Table为表名
16 
17 Select Top n-m+1 * From Table 
18 Where Id>(Select Max(Id) From 
19 (Select Top m-1 Id From Table Order By Id Asc) Temp) 
20 Order By Id Asc

时间: 2024-10-06 17:27:17

用一句SQL取出第 m 条到第 n 条记录的方法的相关文章

“取出数据表中第10条到第20条记录”的sql语句+select top 使用方法

1.首先.select top使用方法: 參考问题  select top n * from和select * from的差别 select * from table --  取全部数据.返回无序集合 select top n * from table  -- 依据表内数据存储顺序取前n条,返回无序集合 select * from table order by id desc -- 取全部数据.按id逆序返回有序列表 select top n * from table order by id d

用一条SQL语句取出第 m 条到第 n 条记录的方法

原文:用一条SQL语句取出第 m 条到第 n 条记录的方法   --从Table 表中取出第 m 条到第 n 条的记录:(Not In 版本) SELECT TOP n-m+1 * FROM Table WHERE (id NOT IN (SELECT TOP m-1 id FROM Table )) --从TABLE表中取出第m到n条记录 (Exists版本) SELECT TOP n-m+1 * FROM TABLE AS a WHERE Not Exists (Select * From 

“取出数据表中第10条到第20条记录”的sql语句+select top 用法

1.首先,select top用法: 参考问题  select top n * from和select * from的区别 select * from table --  取所有数据,返回无序集合 select top n * from table  -- 根据表内数据存储顺序取前n条,返回无序集合 select * from table order by id desc -- 取所有数据,按id逆序返回有序列表 select top n * from table order by id des

sql取出某一列不重复数据的ID解决办法

取出某一列不重复数据的ID表A有ID,BID,ITime三列BID可能会有重复的现在要从A表根据ITime降序排序取出ID来,且如果BID重复就只取第一条数据的ID应该如何实现?------解决方案-------------------- 如果id是递增的select min(id),BID,max(date)from tbl group by BID sql取出某一列不重复数据的ID解决办法,布布扣,bubuko.com

一句SQL语句,可能就是一个定时炸弹

一句小小的SQL语句,在数据量很小的时候,可能是一句相当完美的语句.但是随着数据量的不断增加,你是否能想到他带来的灾难性的后果呢?那么,什么样的SQL语句才算好的语句呢? 对于SQL语句,很多人上来就是select *,不用想,对于数据量大的表来说,这样的语句无非是致命的.而一个好的数据库管理员,在设计数据库时,就应该想到当数据量很大很大时,就应当有所准备. 最近在做一个查询统计, 因为一直用本机的数据库,数据量不是很大,即使查询时等1s也没什么感觉,但是当连接到真正的数据库上,那等待的感觉,只

用一句sql语句更新两个表并可更新对应的字段的值

ACCESS 例子: insert into products (ProNumber,CASNumber,Cnname,Price,Enname,Baozhuang,Pinpai) select ProNumber,CASNumber,Cnname,Price,Enname,Baozhuang,Pinpai from product22 1.用一句sql从一个表里面取出数据导入另外一个表里面.这个对不同程序之间的数据转换很有用处,而且速度快,数据完整: insert into table1 (c

诊断一句SQL不走索引的原因

from http://www.itpub.net/thread-1852897-1-1.html 有论坛朋友在上面的帖子里问SQL为什么不走索引,正好这两天我也刚刚在看SQL优化,于是试着回答了一下. 下面是原来的SQL: select o.order_id as orderId  from order_info o, member mwhere m.member_id = o.member_id   and o.is_delete = 'N'   /*and (to_date(nvl(o.p

php函数mysql_query批量执行多句sql语句

正常情况下用php的mysql_query函数是不能批量执行多句CREATE TABLE之类的语句的: 而有些场景:比如说有一个sql备份文件.又或是程序初始化时创建数据表结构的时候需要批量执行文件中的sql语句: 解决这个问题可以用explode函数按';'号把sql语句拆成数组:再通过循环执行mysql_query即可:因为每句sql都是以';'号结束的: 但是考虑到sql语句中可能有实体符号  之类的:如果按';'号来拆:容易误伤:所以用preg_split正则来拆更靠谱: 示例环境: s

sql数据库中查询第几条到第几条的数据

通用方法: select top 500 * from (select top 1000 * from UserSearchDatas order by ID) a order by ID desc sql数据库中查询第几条到第几条的数据,布布扣,bubuko.com